异常简介
异常类的继承关系
异常类的体系结构
Object 类的直接子类Throwable描述了所有被虚拟机抛出的非正常状
况。一般情况下很少用Throwable,而是使用它的两个子类Error、
Exception。
Error类特指应用程序在运行期间发生的严重错误。如:虚拟机内存用尽
、堆栈溢出等等。一般情况下这种错误都是灾难性的,所以没有必要使
用异常处理机制处理Error。
Exception类有几十个子类,描述了不同类型的异常,其中:
以RuntimeException为代表的一些类,称为非检查性异常(unchecked
Exception),
以IOException为代表的一些类为检查性异常(checked Exception)。所谓
的检查和非检查是指编译器在编译时是否检查。如果代码中存在检查性异常
,必须进行异常处理,否则编译时不能通过;而非检查性异常编译时不进行
检查,到运行时才会显现。
异常类型
*检查性异常(checked exception)
若系统运行时可能产生该类异常,则必须写出相应的处理代码,否则无法通
非RuntimeException
过编译
*非检查型异常(unchecked exception)
若系统运行时可能产生该类异常,则不必在程序中声明对该类异常的处理,
就可以编译执行
RuntimeException:运行时异常
异常的类型
异常处理机制
异常处理机制过程
抛出异常-捕获异常-处理异常
java中可用于处理异常的两种方式:
*自行处理:可能引发异常的语句封入在try块内,而处理异常的相应语句封入catch块内。
我们可以有多个catch块,以捕获不同类型的异常。
try{…}和catch( ){…}之间不可以添加任何代码
最后一个catch块中的形参为Exception类型,它是所有异常
类的父类,任何异常都可以传参到该块中,该块可以处理任何类型的异
常。因此,这个catch块只能放到最后面,否则所有的异常都被它处理了
,其他的catch块就不能分门别类的起作用了。
*回避异常:在方法声明中包含throws子句,通知潜在调用者,如果发生了异常,必须由调用者处理。
finally异常处理机制
finally语句放在try,,,,catch后
finally语句中的代码块不管异常是否被捕获总是要执行。
通常在finally语句中可以进行资源的清除操作,如:关闭打开文件、删
除临时文件
对应finally代码中的语句,即使try代码块和catch代码块中使用了
return语句退出当前方法或般若break跳出某个循环,相关的finally代
码块都有执行。
当try或catch代码块中执行了System.exit(0)时,finally代码块中的内
容不被执行
throws关键字
如果一个方法中语句执行时可能生成某种异常,但是并不能确定如何处理,则可以在程序所在的函数声明后,使用throws关键字抛出异常
位置:函数参数列表的后面
throws关键字后面,可以跟多个异常,中间用逗号分割
throws关键字抛出的异常,由调用该函数的函数处理。
方法中如果用throws关键字抛出:
*非检查型异常:上一级去除异常,直到不抛出异常。
*检查性异常:在调用该函数内try-catch,把异常处理掉。那不往上级抛出异常,程序正常执行,上一级方法并不知道曾经产生异常。
用throws声明方法抛出异常,不进行处理,谁调用谁负责处理。
throw语句
异常是通过关键字throw抛出,程序可以通过throw语句引发明确的异常。
throw语句用在方法体内,表示抛出异常,由方法体内的语句处理。不能单
独使用,要么和try.. catch…一起使用,要么和throws一起使用。
throw语句的操作数一定是Throwable类类型或Throwable子类类型的一个
对象
自定义异常类
如果java提供的异常类型不能满足程序设计需要,我们可以自己定义异常类型。
用户自定义的异常类应为Exception类(或Exception类的子类)的子类。