㈠ java异常分类
一、概念
如果某个方法不能按照正常的途径完成任务,就可以通过另一种路径退出方法。在这种情况下
会抛出一个封装了错误信息的对象。此时,这个方法会立刻退出同时不返回任何值。另外,调用
这个方法的其他代码也无法继续执行,异常处理机制会将代码执行交给异常处理器。
二、异常分类
Throwable 是 Java 语言中所有错误或异常的超类,在 Java 中只有 Throwable 类型的实例才可以被抛出(throw)或者捕获(catch),它是异常处理机制的基本组成类型。
实例分为 Error 和 Exception 两种。
2.1、Error
Error 类是指 java 运行时系统的内部错误和资源耗尽错误。应用程序不会抛出该类对象。如果
出现了这样的错误,除了告知用户,剩下的就是尽力使程序安全的终止。
2.2、Exception
Exception 又有两个分支 , 一个是运行时异常 RuntimeException , 一 个是检查异常 CheckedException。
RuntimeException 如 :NullPointerException 、 ClassCastException ;
CheckedException 如: I/O 错误导致的 IOException、SQLException。
RuntimeException 是那些可能在 Java 虚拟机正常运行期间抛出的异常的超类。 如果出现 RuntimeException,那么一
定是程序员代码书写导致的错误.
CheckedException:一般是外部错误,这种异常都发生在编译阶段,Java 编译器会强
制程序去捕获此类异常,即会出现要求你把这段可能出现异常的程序进行 try catch,该类异常一
般包括几个方面:
试图在文件尾部读取数据
试图打开一个错误格式的 URL
试图根据给定的字符串查找 class 对象,而这个字符串表示的类并不存在
三、异常的处理方式
3.1、不处理
遇到异常问题不进行具体处理,而是继续抛给调用者 (throw,throws)
抛出异常有三种形式,一是 throw,再就是 throws,还有一种系统自动抛异常。
public static void main(String[] args) {
String s = "abc";
if(s.equals("abc")) {
/** 手动抛出一个数字格式化异常 **/
throw new NumberFormatException();
} else {
System.out.println(s);
}
}
int div(int a,int b) throws Exception{
return a/b;
}
3.2、处理
try catch 捕获异常针对性处理方式
四、Throw 和 throws 的区别
throws 用在函数上,后面跟的是异常类,可以跟多个;
语法:(修饰符)(方法名)([参数列表])[throws(异常类)]{……}
public void doA(int a) throws Exception1,Exception3{……}
throw 用在函数内,后面跟的是异常对象。
throws E1,E2,E3只是告诉程序这个方法可能会抛出这些异常,方法的调用者可能要处理这些异常,而这些异常E1,E2,E3可能是该函数体产生的。
throw则是明确了这个地方要抛出这个异常。
结合来看:
void doA(int a) throws IOException,{
try{
......
}catch(Exception1 e){
throw e;
}catch(Exception2 e){
System.out.println("出错了!");
}
if(a!=b)
throw new Exception3("自定义异常");
}
throws 用来声明异常,让调用者知道该功能可能会出现的问题(比如上方的 IO 异常),可以给出预先的处理方式;
throw 抛出具体的问题对象,执行到 throw,功能就已经结束了,跳转到调用者,并将具体的问题对象抛给调用者。
也就是说 throw 语句独立存在时,下面不要定义其他语句,因为执行不到。
概括:
throws 表示出现异常的一种可能性,并不一定会发生这些异常;
throw 则是抛出了异常,执行 throw 则一定抛出了某种异常对象。
五、总结
了解 Exception、Error 两种异常的区别,面试可能会问。
区分 throws、throw使用维度。
㈡ 在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中已检查异常和位未检查异常是什么二者有何区别
1、含义不同:检查异常就是编译器要求你必须处置的异常。不知道你编程的时候有没有遇到过,你写的某段代码,编译器要求你必须要对这段代码trycatch,或者throwsexception。
非检查异常是编译器不要求强制处置的异常,虽然有可能出现错误,但是不会在编译的时候检查。
2、运行时情况不同:运行时异常都是RuntimeException类及其子类异常,如NullPointerException(空指针异常)、IndexOutOfBoundsException(下标越界异常)等,这些异常是非检查异常,程序中可以选择捕获处理,也可以不处理。
这些异常一般是由程序逻辑错误引起的,程序应该从逻辑角度尽可能避免这类异常的发生。
运行时异常的特点是Java编译器不会检查它,也就是说,当程序中可能出现这类异常,即使没有用try-catch语句捕获它,也没有用throws子句声明抛出它,也会编译通过。
运行时异常是RuntimeException以外的异常,类型上都属于Exception类及其子类。从程序语法角度讲是必须进行处理的异常,如果不处理,程序就不能编译通过。
如IOException、SQLException等以及用户自定义的Exception异常,一般情况下不要自定义检查异常。
3、解决方式不同:检查异常继续抛出,消极的方法,一直可以抛到java虚拟机来处理,就是通过throwsexception抛出。用try...catch捕获。注意,对于检查的异常必须处理,或者必须捕获或者必须抛出。
对未检查的异常捕获;继续抛出;不处理。
一般是不处理的,因为你很难判断会出什么问题,而且有些异常你也无法运行时处理,比如空指针,需要人手动的去查找,而且,捕捉异常并处理的代价远远大于直接抛出。
(3)java检测异常扩展阅读:
所有异常类型都是Throwable类的子类,它包含Exception类和Error类,Exception又包括checkedexception和uncheckedexception。
uncheckedexception:Java编译器不要求对未检查异常一定捕获或抛出,可以不做处理。此类异常通常是在逻辑上有错误,可以通过修改代码避免。在eclipse中(保存即编译)编译后此类异常发生处会报错。
checkedexception:Java编译器要求对检查异常必须捕获或抛出,代码逻辑没有错误,但程序运行时会因为IO等错误导致异常,你在编写程序阶段是预料不到的。
如果不处理这些异常,程序将来肯定会出错。所以编译器会提示你要去捕获并处理这种可能发生的异常,不处理就不能通过编译。