异常----finally{一定会被执行的语句}
通常用于关闭资源
该动作无论是否操作成功,一定会被执行
异常----处理语句的其他格式
//第一个格式
try{
}
catch{
}
//第二个格式
try{
}
catch{
}
finally{
}
//第三个格式
try{
}
finally{
}
catch用于处理异常,如果没有catch就代表异常没有被处理过
如果该异常是检测时异常,则必须被声明
eg.
class Demo{
try{
throw new Exception();
}
finally{
//关闭资源
}
}
**只要问题被解决,则不必要声明
异常在子父类覆盖中的体现
1.子类在覆盖父类时,如果父类的方法抛出异常,那么子类的覆盖方法
只能抛出父类的异常或者该异常的子类
2. 如果父类方法抛出多个异常,那么子类在覆盖该方法时,只能抛出父类异常的子集
3.如果父类或者接口的方法中没有异常抛出,那么子类在覆盖方法时,不能抛出异常
如果子类方法发生了异常,必须进行try处理,绝对不能抛
class AException extends Exception{
}
class BException extends AException{
}
class CException extends Exception{
}
class Fu{
void show()throws AException{
}
}
class Zi extends Fu{
void show()throws BException{ //或者throws AException
}
}
/*
Exception
|--AException
|--BException
|--CException
*/
练习
v1.0 报错
/*
有一个圆形和长方形
都可以获取面积,如果出现非法的数值,视为获取面积出现问题
*/
class NoValueException extends Exception{
NoValueException(String msg){
super(msg);
}
}
interface Shape{
void getArea();
}
class Rec implements Shape{
private int len,wid;
Rec(int len,int wid)throws NoValueException{
if(len<=0||wid<=0){
throw new NoValueException("出现非法值");
}
this.len=len;
this.wid=wid;
}
public void getArea(){
System.out.println(len*wid);
}
}
class ExceptionTest1{
public static void main(String[] args){
try{
Rec r=new Rec(-3,4);
r.getArea();
}
catch(NoValueException e){
System.out.println(e.toString());
}
System.out.println("OVER");
}
}
v2.0 数值非法停止程序运行
/*
有一个圆形和长方形
都可以获取面积,如果出现非法的数值,视为获取面积出现问题
*/
class NoValueException extends RuntimeException{
NoValueException(String msg){
super(msg);
}
}
interface Shape{
void getArea();
}
class Rec implements Shape{
private int len,wid;
Rec(int len,int wid){
if(len<=0||wid<=0){
throw new NoValueException("出现非法值");//throw new RuntimeException()亦可
}
this.len=len;
this.wid=wid;
}
public void getArea(){
System.out.println(len*wid);
}
}
class ExceptionTest1{
public static void main(String[] args){
Rec r=new Rec(-3,4);
r.getArea();
System.out.println("OVER");
}
}
总结
异常:对问题的描述,将问题进行对象的封装
体系
Throwable
|--Error
|--Exception
|--RuntimeException
特点:异常体系中的所有类以及建立的对象都具有可抛性
即可以被throw和throws关键字操作
只有异常体系具备这个特点
throw和throws的用法:
throw定义在函数内,用于抛出异常对象
throws定义在函数上,用于抛出异常类,可以抛出多个用逗号隔开
当函数内容有throw抛出异常对象,并未进行try处理
必须在函数上声明,都在编译失败
**RuntimeException除外,即使抛出也可以不声明
如果函数声明了异常,调用者需要进行处理,可以是throws也可以是try
异常有两种:
编译时异常:该异常在编译时如果没有处理(没有throw||try),编译失败
该异常被标识,表示这可以被处理
运行时异常:在编译时,不需要处理,编译器不检查
该异常的发生,建议不处理,让程序停止,需要对代码进行修正
异常处理语句
try{需要被检测的代码}
catch(){处理异常的代码}
finally{一定会被执行的语句}//通常定义关闭资源代码
/*
可以try{}catch(){}
也可以try{}finally{}
如果执行到System.exit(0),finally语句则不会执行
*/
自定义异常:定义类继承Exception或者RuntimeException
1.为了让该自定义类具备可抛性
2.让该类具备操作异常的共性方法
当定义自定义异常的信息时,可以使用父类已经定义好的功能
将异常信息传递给父类的构造函数
class MyException extends Exception{
MyException(String msg){
super(msg);
}
}
异常的好处:
1.将问题进行封装
2.将正常流程代码和问题处理代码相分离,方便于阅读
异常的处理原则:
1.处理方式有try或者throws
2.调用到抛出异常的功能时,抛出几个就处理几个
3.多个catch,父类的catch放到最下面
4.catch内需要定义针对性的处理方式,捕获到无法处理的异常时可以继续在catch中抛出
catch(AException e){
throw e
}
如果不能处理的异常不属于该功能出现的异常,可以转换后再抛出和该功能相关的异常
或者异常可以处理,当需要将异常产生的和本功能相关的问题提供出去
当调用者知道并处理,也可以将捕获异常处理后转换成新的异常
try{throw new AException}
catch(AException e){
//对AException的处理
throw new BException();
}
注意事项
在子父类覆盖时:
1.子类抛出的异常必须是父类异常的子类或者子集
2.如果父类或者接口没有异常抛出时,子类覆盖出现异常,只能try不能抛