当前位置:首页 » 编程语言 » java异常的处理

java异常的处理

发布时间: 2023-07-31 01:48:05

Ⅰ 在java中常出现的异常和解决方法

1. java.lang.nullpointerexceptionx0dx0a 这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针",简单地说就是调用了未经初始化的对象或者是不存在的对象,这个错误经常出现在创建图片,调用数组这些操作中,比如图片未经初始化,或者图片创建时的路径错误等等。对数组操作中出现空指针,很多情况下是一些刚开始学习编程的朋友常犯的错误,袭悔即把数组的初始化和数组元素的初始化混淆起来了。数组的初始化是对数组分配需要的空间,而初始化后的数组,其中的元素并没有实例化,依然是空的,所以还需要对每个元素都进行初始化(如果要调用的话)x0dx0ax0dx0a 2. java.lang.classnotfoundexceptionx0dx0a 这个异常是很多原本在jb等开发环境中开发的程序员,把jb下的程序包放在wtk下编译经常出现的问题,异常的解释是"指定的类不存在",这里主要考虑一下类的名称和路径是否正确即可,如果是在jb下做的程序包,一般都是默认加上package的,所以转到wtk下后要注意把package的路径加上。x0dx0ax0dx0a 3. java.lang.arithmeticexceptionx0dx0a 这个异常的解释是"数学运算异常",比如程序中出现了除以零这样的运算就会出这样的异常,对这种异常,大家就要好好检查一下自己程序中涉及到数学运算的地方,公式是不是有不妥了。x0dx0ax0dx0a 4. java.lang.x0dx0a 这个异常相信很多朋友也经常遇到过,异常的解释是"数组下标越界",现在程序中大多都有对数组的操作,因此在调用数组的时候一定要认真检查,看自己调用的下标是不是超出了数组的范围,一般来说,显示(即直接用常数当下标)调用不太容易出这样的错,但隐式(即用变量表示下标)调用就经常出错了,还有一种情况,是程序中定义的数组的长度是通过某些特定方法决定的,不是事先声明的,这个时候,最好先查看一下数组的length,以免出现这个异常。x0dx0ax0dx0a 5. java.lang. 这个异常的解释是"方法的参数错误",很多j2me的类库中的方法在一些情况下都会引发这样的错误,比如音量调节方法中的音量参数如果写成负数就会出现这个异常,再比如g.setcolor(int red,int green,int blue)这个方法中的三个值,如果有超过255的也会出现这个异常,因此一旦发现这个异常,我们要做的,就是赶紧去检查一下方法调用中的参数传递是不是出现了错误。x0dx0ax0dx0a 6. java.lang.illegalaccessexceptionx0dx0a 这个异常的解释是"没有访问权限",当应用程序要调用一个类,但当前的方法即没有对该类的访问权限便会出现这个异常。对程序中用了package的情况下要注意这个异常。x0dx0ax0dx0a 其他还有很多异常,我就不一一列举了,我要说明的是,一个合格的程序员,需要对程序中常见的问题察慎有相当的了解和相应的解决办法,否则仅仅停留在写程序而不会改程序的话,会极大影响到自己的开发的。关于异常的全部说明,在api里败禅敬都可以查阅。x0dx0ax0dx0a算术异常类:空指针异常类:类型强制转换异常:数组负下标异常:数组下标越界异常:x0dx0ax0dx0a违背安全原则异常:文件已结束异常:EOFExceptionx0dx0ax0dx0a文件未找到异常:字符串转换为数字异常:操作数据库异常:SQLExceptionx0dx0ax0dx0a输入输出异常:IOExceptionx0dx0ax0dx0a方法未找到异常:.lang.抽象方法错误。当应用试图调用抽象方法时抛出。x0dx0ax0dx0ajava.lang.AssertionErrorx0dx0ax0dx0a断言错。用来指示一个断言失败的情况。x0dx0ax0dx0ajava.lang.类循环依赖错误。在初始化一个类时,若检测到类之间循环依赖则抛出该异常。x0dx0ax0dx0ajava.lang.ClassFormatErrorx0dx0ax0dx0a类格式错误。当Java虚拟机试图从一个文件中读取Java类,而检测到该文件的内容不符合类的有效格式时抛出。x0dx0ax0dx0ajava.lang.Errorx0dx0ax0dx0a错误。是所有错误的基类,用于标识严重的程序运行问题。这些问题通常描述一些不应被应用程序捕获的反常情况。x0dx0ax0dx0ajava.lang.初始化程序错误。当执行一个类的静态初始化程序的过程中,发生了异常时抛出。静态初始化程序是指直接包含于类中的static语句段。x0dx0ax0dx0ajava.lang.违法访问错误。当一个应用试图访问、修改某个类的域(Field)或者调用其方法,但是又违反域或方法的可见性声明,则抛出该异常。x0dx0ax0dx0ajava.lang.不兼容的类变化错误。当正在执行的方法所依赖的类定义发生了不兼容的改变时,抛出该异常。一般在修改了应用中的某些类的声明定义而没有对整个应用重新编译而直接运行的情况下,容易引发该错误。x0dx0ax0dx0ajava.lang.实例化错误。当一个应用试图通过Java的new操作符构造一个抽象类或者接口时抛出该异常.x0dx0ax0dx0ajava.lang.InternalErrorx0dx0ax0dx0a内部错误。用于指示Java虚拟机发生了内部错误。x0dx0ax0dx0ajava.lang.LinkageErrorx0dx0ax0dx0a链接错误。该错误及其所有子类指示某个类依赖于另外一些类,在该类编译之后,被依赖的类改变了其类定义而没有重新编译所有的类,进而引发错误的情况。x0dx0ax0dx0ajava.lang.未找到类定义错误。当Java虚拟机或者类装载器试图实例化某个类,而找不到该类的定义时抛出该错误。x0dx0ax0dx0ajava.lang.NoSuchFieldErrorx0dx0ax0dx0a域不存在错误。当应用试图访问或者修改某类的某个域,而该类的定义中没有该域的定义时抛出该错误。x0dx0ax0dx0ajava.lang.NoSuchMethodErrorx0dx0ax0dx0a方法不存在错误。当应用试图调用某类的某个方法,而该类的定义中没有该方法的定义时抛出该错误。x0dx0ax0dx0ajava.lang.OutOfMemoryErrorx0dx0ax0dx0a内存不足错误。当可用内存不足以让Java虚拟机分配给一个对象时抛出该错误。x0dx0ax0dx0ajava.lang.堆栈溢出错误。当一个应用递归调用的层次太深而导致堆栈溢出时抛出该错误。x0dx0ax0dx0ajava.lang.ThreadDeathx0dx0ax0dx0a线程结束。当调用Thread类的stop方法时抛出该错误,用于指示线程结束。x0dx0ax0dx0ajava.lang.UnknownErrorx0dx0ax0dx0a未知错误。用于指示Java虚拟机发生了未知严重错误的情况。x0dx0ax0dx0ajava.lang.未满足的链接错误。当Java虚拟机未找到某个类的声明为native方法的本机语言定义时抛出。x0dx0ax0dx0ajava.lang.不支持的类版本错误。当Java虚拟机试图从读取某个类文件,但是发现该文件的主、次版本号不被当前Java虚拟机支持的时候,抛出该错误。x0dx0ax0dx0ajava.lang.VerifyErrorx0dx0ax0dx0a验证错误。当验证器检测到某个类文件中存在内部不兼容或者安全问题时抛出该错误。x0dx0ax0dx0ajava.lang.虚拟机错误。用于指示虚拟机被破坏或者继续执行操作所需的资源不足的情况。x0dx0ax0dx0ajava.lang.算术条件异常。譬如:整数除零等。x0dx0ax0dx0ajava.lang.x0dx0ax0dx0a数组索引越界异常。当对数组的索引值为负数或大于等于数组大小时抛出。x0dx0ax0dx0ajava.lang.数组存储异常。当向数组中存放非数组声明类型对象时抛出。x0dx0ax0dx0ajava.lang.类造型异常。假设有类A和B(A不是B的父类或子类),O是A的实例,那么当强制将O构造为类B的实例时抛出该异常。该异常经常被称为强制类型转换异常。x0dx0ax0dx0ajava.lang.找不到类异常。当应用试图根据字符串形式的类名构造类,而在遍历CLASSPAH之后找不到对应名称的class文件时,抛出该异常。x0dx0ax0dx0ajava.lang.不支持克隆异常。当没有实现Cloneable接口或者不支持克隆方法时,调用其clone()方法则抛出该异常。x0dx0ax0dx0ajava.lang.x0dx0ax0dx0a枚举常量不存在异常。当应用试图通过名称和枚举类型访问一个枚举对象,但该枚举对象并不包含常量时,抛出该异常。x0dx0ax0dx0ajava.lang.Exceptionx0dx0ax0dx0a根异常。用以描述应用程序希望捕获的情况。x0dx0ax0dx0ajava.lang.违法的访问异常。当应用试图通过反射方式创建某个类的实例、访问该类属性、调用该类方法,而当时又无法访问类的、属性的、方法的或构造方法的定义时抛出该异常。x0dx0ax0dx0ajava.lang.违法的监控状态异常。当某个线程试图等待一个自己并不拥有的对象(O)的监控器或者通知其他线程等待该对象(O)的监控器时,抛出该异常。x0dx0ax0dx0ajava.lang.违法的状态异常。当在Java环境和应用尚未处于某个方法的合法调用状态,而调用了该方法时,抛出该异常。x0dx0ax0dx0ajava.lang.违法的线程状态异常。当县城尚未处于某个方法的合法调用状态,而调用了该方法时,抛出异常。x0dx0ax0dx0ajava.lang.索引越界异常。当访问某个序列的索引值小于0或大于等于序列大小时,抛出该异常。x0dx0ax0dx0ajava.lang.实例化异常。当试图通过newInstance()方法创建某个类的实例,而该类是一个抽象类或接口时,抛出该异常。x0dx0ax0dx0ajava.lang.被中止异常。当某个线程处于长时间的等待、休眠或其他暂停状态,而此时其他的线程通过Thread的interrupt方法终止该线程时抛出该异常。x0dx0ax0dx0ajava.lang.数组大小为负值异常。当使用负数大小值创建数组时抛出该异常。x0dx0ax0dx0ajava.lang.属性不存在异常。当访问某个类的不存在的属性时抛出该异常。x0dx0ax0dx0ajava.lang.方法不存在异常。当访问某个类的不存在的方法时抛出该异常。x0dx0ax0dx0ajava.lang.空指针异常。当应用试图在要求使用对象的地方使用了null时,抛出该异常。譬如:调用null对象的实例方法、访问null对象的属性、计算null对象的长度、使用throw语句抛出null等等。x0dx0ax0dx0ajava.lang.数字格式异常。当试图将一个String转换为指定的数字类型,而该字符串确不满足数字类型要求的格式时,抛出该异常。x0dx0ax0dx0ajava.lang.RuntimeExceptionx0dx0ax0dx0a运行时异常。是所有Java虚拟机正常操作期间可以被抛出的异常的父类。x0dx0ax0dx0ajava.lang.SecurityExceptionx0dx0ax0dx0a安全异常。由安全管理器抛出,用于指示违反安全情况的异常。x0dx0ax0dx0ajava.lang.x0dx0ax0dx0a字符串索引越界异常。当使用索引值访问某个字符串中的字符,而该索引值小于0或大于等于序列大小时,抛出该异常。x0dx0ax0dx0ajava.lang.类型不存在异常。当应用试图

Ⅱ JAVA语言如何进行异常处理

Java通过面向对象的方法进行异常处理,把各种不同的异常进行分类,并提供了良好的接口。

在Java中,每个异常都是一个对象,它是Throwable类或其子类的实例。当一个方法出现异常后便抛出一个异常对象,该对象中包含有异常信息,调用这个对象的方法可以捕获到这个异常并可以对其进行处理。

Java的异常处理是通过5个关键词来实现的:try、catch、throw、throws和finally。一般情况下是用try来执行一段程序,如果系统会抛出(throw)一个异常对象,可以通过它的类型来捕获(catch)它,或通过总是执行代码块(finally)来处理;try用来指定一块预防所有异常的程序;

catch子句紧跟在try块后面,用来指定你想要捕获的异常的类型;

throw语句用来明确地抛出一个异常;

throws用来声明一个方法可能抛出的各种异常(当然声明异常时允许无病呻吟);

finally为确保一段代码不管发生什么异常状况都要被执行。

Ⅲ 应用技巧:Java中的异常处理

异常处理是初学者经常忽视执行的编程技巧。然而,当他们完成了一项大型项目后,就会发现仅仅停留在表面的工作是不够的。在本文中,我们将对异常处理进行讨论,并为大家解释其重要性,尤其是要告诉大家怎样处理这些情况。
首先,让我们解释一下什么是异常情况,通常也称例外。正如在其他的编程语言中那样,它也适用于Java:异常情况是那些在运行时出现错误的情况。这些错误并非真正的错误,因为他们是一些例外。我们可以将这些情况理解为必须解决的异常事件,否则程序将无法继续执行。所以我们就有必要了解怎样处理异常事件。
在异常事件的例子中最显着的应该是在程序执行时,运行时的分配变成了零。这样程序就无法执行,于是Java就会抛出一个异常事件,确切点说是ArithmeticException。从Java程序员的角度来看,异常事件是对象。抛出异常事件类似于抛出对象。但是,并非所有的对象都可以被抛出。
为了充分理解可毕山抛出的异常事件,整个类层次结构的一些部分要消数闷被提交。主要的类称为Throwable。这个类拥有两个子类:Exception 和Error。一个异常事件对象应从Throwable的类中传出。意味着它应该是Exception子类或Error子类的一个对象实例。这些都可以在 java.lang数据包中找到。
异常处理就是捕捉可能在运行时被抛出的异常事件的一项技术。Java通过try-catch-finally的异常处理语句为我们提供了强大的异常处理解决方案。而在另一方面,你也可以使用已经声明的异常事件,如ArithmeticException, NullPointerException等。其他类扩展了Exception 类,如IOException子类。
此外,我们应该注意到异常事件包含了两种情况:检查过的和没检查的。技术上,我们认为没检查过的异常事件RuntimeExceptions。这些不需要在抛出的语句中作出声明,而且对它们的捕捉也是选择性的。不过,它们一般不会有什么影响,如果程序员根本不能发现它们的存在。在大多数情况下,这些都是逻辑性的编程错误,如NullPointerException或者ArrayIndexOutOfBounds。
同时,对异常事件进行技术性检查也迫使程序员对其进行处理和管理,意味着要对其进行单独捕捉并覆盖。这些都来自Exceptions类和它的子类,包括我们之前讨论过的RuntimeExceptions。检查过的异常事件要求异常事件处理因为它们有可拿弯能导致程序终止。
现在,我们对异常事件有了个基本的了解,下面就让我们启动集成开发环境开始编码吧!
异常处理
前面我们提到了异常处理就是指处理代码中的异常事件,或者在运行时向运行引擎抛出异常事件,在引擎末端它会搜索异常事件处理例程。它使用包含了一系列方法调用的调用堆栈进行搜索。
一般而言,异常事件可能因为包含一个异常活动或其他异步异常导致的。我们讨论的异常事件包括了一些基本的处理议题:怎样捕捉和处理这些异常事件。
Java允许我们创建自己的Exception对象和类,但是会有一个关键的请求。这些对象和类必须是扩展的Exception类。编码标准要求异常事件应该充分命名,意味着它们的名字就代表了其本身。
throw new Exception(“ This is an exception!”)
下面,我们看看要怎样捕捉和处理这些异常事件。检查以下代码:
try{
// this is the block of code where the exception happens
// sometimes called as source/root of exception
// or even called as tricky block or tricky method

catch{Exception_Typel e) {
// dealing with this kind of exception

Catch (Exception_Type2 e) {
// dealing witn this kind of exception

//... unlimited number of catches are possible
finally {
// this block of code is always executed

try-catch-finally语句的第一个部分是尝试阻止。这是异常事件有可能发生的部分。通常,我们建议代码行用最小的数量来编写,因为它们只会在异常事件发生的时候执行。这种情况发生时,执行会跳转去捕捉那些异常事件被比较的块中。如果它们匹配,那么就可以处理异常事件。
不论尝试阻止的时候,异常事件会不会发生,或不管能不能得到处理,阻止总会执行。由于它总是被执行,所以我们推荐你在这里做一些清理。因此,正如所预料的那样,执行起来就是具有选择性的。
Try-catch模块的结构类似于switch-case的结构。在检查过的需要处理的异常事件中,是有可能在相同方法中将其处理或者抛出的。后者可以通过关键词抛出。在这种情况下,异常事件的种类必须在方法签名中被指定。看这个例子:
Void myMethod () throws SomeKindOfException{
// method goes here
}
接下来,我们将为大家展示更多的异常处理实例。
初学者常常与非匹配数据类型纠缠不清。通常,它们会引发一些问题,例如,在做加法时出现非数字型代码。下面给大家展示的代码中,出现了异常处理的工作环境。检查该网页以完成嵌入式Exception种类的清单。现在,我们要处理NumberFormatException 的发生。
public static void main (String args[] ) {
double sum= 0;
for (int i=0; i﹤args. length; ++1)
try {
sum+= Double.parseDboule (args[i]);
}
Catch (NumberFormatException e) {
Ststem.out.printIn(args[i] + “non-numeric data on”);
}
System.out.printIn(“Total sum: “+ sum);
}
正如你所见到的,它和命令行参数一起运行,而且一旦轮到非数字型参数,它就会写入system.out,意指出现的问题。但是项目会继续进行,因为try模块是循环的。否则,没有合适的异常处理,项目就会终止。用这种方式总和还是可以计算处理并在最后显示处理。 我们来看看另一个例子。在这个例子中,我们会要建立自己的异常实例类,该类扩展了其母Exception类。应用程序会模拟用于异常处理和抛出的堆栈机制,如堆栈是满的或者是空的。检查一下。
Public class StackException extends Exception {
Public StackException (String text) {
Super (text)
}
}
现在让我们创建一个Stack类。注意push和pop方法。它们正抛出StackException,而这一动作由方法签名导入。此外,还有一个if条件,且条件满足时,异常事件会被抛出。否则,一切都会顺利运行。
public class Stack {
private final int SIZE = 100;
private Object st[];
private int size;
private int sp;
public Stack (int size) {
if (size < MAXSIZE)
this.size = size;
else
this.size = MAXSIZE;
this.st = new Object [size];
this.sp = -1;
}
public void push (Object o) throws StackException {
if (sp == this.size - 1)
throw new StackException ("Stack is full");
this.st [++this.sp] = o;
}
public Object pop () throws StackException {
if (sp == -1)
throw new StackException ("Stack is empty");
Object o = this.st [this.sp];
this.sp--;
return o;
}
public boolean isEmpty() {
return this.sp == -1;
}
}
好的,现在是时候写一写Main class连同主要方法了。在这一部分,请对try-catch语句给予更多关注。有两类异常情况可以被捕捉到。你也可以很容易地找出它们。
public class Main {
public static void main (String args[]) {
Stack s = new Stack (10);
for (int i = 0; i <= 10; ++i)
try {
s.push (new Integer(i));
}
catch (StackException e) {
System.out.println (e);
}
while (! s.isEmpty() ) {
try {
System.out.println( (Integer)(s.pop()) );
}
catch (StackException e) {
System.out.println(e);
}
}
}
}
当然,这里也会有附带输出。如你所见,第一行显示出的就是异常事件,因为我们要用11个要素填补堆栈,因此,在循环到isEmpty是错误的时,异常事件不会抛出。
Stack is full
练习几次以上的几段代码。如果异常事件被抛出但是却能够正确被处理那就不要感到惊讶。这就是异常处理的神奇之处。
总结
在这篇文章里我们就异常处理的实用性和重要性进行了分析。我们都知道,不管是检查过的或是未经检查的,程序员都要处理好异常事件,否则可能出现程序的异常终止。我们强调要将理论与实践相结合。坦率地说,本文虽只是冰山一角,但一些基本的知识已经介绍给了大家。希望能在异常处理方面对大家有所帮助。

Ⅳ Java是怎样处理异常问题的

第一:try{}catch{}捕捉异常处理。
try语句里面实现的是主事件流,而catch里面实现的是异常流。
自定义大量的Exception类,只是代表非主事件流的发生的,用来进行那些分支流程的流程控制的。
在异常捕获后返回一个变量,该变量参与正常的业务流程。
第二:业务层处理业务时抛出异常,下次处理。(会影响性能)
返回变量是一种做法;抛出异常是一种做法。
而不是两者都用,返回变量是面向过程的编程方法;抛出异常更OO。

Ⅳ Java 求大神们解答:自定义异常,处理异常

Java 允许我们定义自己的异常,这样的异常就称为自定义异常。定义自定义异常的方式是继承 Exception 类,然后定义一个类来代表该异常。
下面是定义自定义异常类的示例:
================
public class MyException extends Exception {
public MyException() {
super();
}
public MyException(String message) {
super(message);
}
}
================
这里定义了一个名为 MyException 的类,它继承了 Exception 类,并定义了两个构造方法,一个是无参构造方法,另一个是带有一个字符串参数的构造方法,该字符串参数用于传入错误信息。
接下来,我们可以在可能抛出异常的方法中使用 throws 关键字声明该方法可能抛出的异常,并在方法中使用 throw 语句抛出异常。例如:
================

public class UsingMyException {
public void f() throws MyException {
System.out.println("抛出异常MyException 从 f()方法");
throw new MyException();
}
public void g() throws MyException {
System.out.println("抛出异常MyException 从 g()方法");
throw new MyException("从g()方法中抛出异常");
}
}
================
这里我们定义了一个名为 UsingMyException 的类,它包含两个方法: f() 和 g()。两个方法都使用了 throws 关键字声明它们可能会抛出 MyException 异常,并在方法内部使用 throw 语句抛出该异常

热点内容
寒灵之剑脚本 发布:2025-02-07 06:57:12 浏览:118
解压的窗口 发布:2025-02-07 06:44:34 浏览:797
android身份证 发布:2025-02-07 06:36:43 浏览:430
python的库在哪 发布:2025-02-07 06:30:24 浏览:348
带锁的铅笔如何改密码 发布:2025-02-07 06:18:05 浏览:164
ubuntu搭建samba服务器 发布:2025-02-07 05:52:54 浏览:54
小型企业网如何配置可以互通 发布:2025-02-07 05:33:56 浏览:243
09年crv哪个配置好 发布:2025-02-07 05:17:31 浏览:555
nvm源码编译 发布:2025-02-07 05:13:19 浏览:126
防伪码查询源码 发布:2025-02-07 05:09:39 浏览:770