JAVA学习日志(10-1-异常覆盖特点及总结)

异常----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不能抛

 

转载于:https://my.oschina.net/Almon/blog/726762

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值