异常处理P369-383
一、比如:客户输入的数据不符合要求,读取的文件不存在,网络是否保持通畅
通常不是代码的逻辑问题,不是代码本身的原因,是一些突发情况。
两类:
Error:JVM内部,资源耗尽(StackOverflowError)(OutMemoryError)
Exepetion:空指针异常,指针越界,读取不存在的文件
解决方案:1.直接终止
2.考虑到异常的发生,准备好解决方案
二、编译时异常:现在就要必须处理
IOException
FileNotFoundException 找不到文件
运行时异常:runtime:运行时的错误,可以不处理 (通常不处理)
ArrayIndexOutOfBoundsException
NullPointerException空指针异常(null) 算数异常
ClassCastException 类型转换异常
NumberFormatException数字格式化异常
InputMisMatch输入不匹配Scanner
ArithmeticException除0异常
三、把可能出现异常的代码用try来括起来
Java异常处理方式:
1.try-catch-finally 最终要解决
2.throws+异常类型-喊人-继续喊人-再继续喊人-------
抓抛模型:
抛出一个对应异常类的对象,之后代码不再执行了。
1.try-catch-finally
处理编译时的异常,使程序在编译时不再报错
使用try括起来,生成一个异常的对象然后和catch中的异常类
匹配,匹配好以后执行对应的方法体。先子类后父类,先小后大
sout(getMessage());//来获取异常处理信息
try外不能用try内声明变量;
Finally一定会被执行:catch内有异常或者有return依然会执行Finally
并且会先执行finally里的语句。
向数据库的连接、输入输出流、网络编程等资源JVM不能进行垃圾回收
需要手动操作就放在Finally中,确定可以把回收资源的操作一定执行。
四、2.throws 抛出异常(没有实际处理掉)最后还需要用try catch
往上抛,交给上级处理。最上级就是main
也必须用try catch的结构处理。异常代码后面的代码将不会执行。
子类抛出的异常不能超过父类;
如果被重写父类方法没有用throws方式处理异常,子类也不能有throws,必须用
try catch 处理
方法的先后关系是递进关系的话,括住一起使用
五、除了系统自动生成,有的时候也需要手动生成一个异常对象,并抛出(throw)
throw 是生成一个异常对象的过程在方法体内
throws 属于异常处理的一种方式,在方法的声明处
六、自定义异常类
1.要继承于现有的类
2.提供一个Uid(Long)
3.提供重载的构造器
实现多种异常和自定义异常
package test0905;
public class EcDef extends Exception {
static final long serialVersionUID = -3387516993124229L;
public EcDef(){}
public EcDef(String msg){
super(msg);
}
}
package test0905;
public class EcmDef {
public static void main(String[] args) {
try{int i = Integer.parseInt(args[0]);
int j = Integer.parseInt(args[1]);
int result = ecm(i,j);
System.out.println(result);}
catch(NumberFormatException e){
System.out.println("数据类型不一致");
}
catch (ArrayIndexOutOfBoundsException e){
System.out.println("缺少命令行参数");
}
catch (ArithmeticException e){
System.out.println("除零异常");
}
catch (EcDef e){
System.out.println(e.getMessage());
}
}
public static int ecm(int i, int j)throws EcDef{
if (i < 0 || j < 0){throw new EcDef("不能輸入负数");}
return i / j;
}
}