这个是jdk 1.8文档中异常的种族描述
可以看出Java异常体系的根类是 Throwable, 当在java代码中写throw抛出异常时,后面跟的对象必然是Throwable或其子类的对象。
然后往下又分为 Exception(异常) 和 Error
其中Exception异常是指一些可以恢复的异常, 例如常见的NullPointerException空指针异常。
Error指的是一些致命的错误,无法通过程序代码手段恢复的异常,例如OutOfMemoryError内存溢出错误。
如果能善用异常机制那么代码使用就会大大提高
本次模拟一个异常实例,验证一下异常的捕获
代码如下
public class ExceptionTest { public static void main(String[] args) { try{ int i = subtraction(); System.out.println(i); }catch (Exception e){ System.out.println("异常 Exception 被捕获 异常信息为:"+e); e.printStackTrace(); } } public static int subtraction(){ int result = 0; try { result = 10 / 0; }catch (RuntimeException e){ System.out.println("运行异常 RuntimeException 被捕获 异常信息"+e); throw new RuntimeException("运行异常"); } return result; } }
我在调用一个方法的时候,该方法会抛出一个runtimeException 异常
然后我调用此方法的程序可能会有其他处理操作,也做了个try…catch 处理,然后验证 主方法的catch是否会执行
结果证明会执行
因为被调用的方法使用throw new RuntimeException("运行异常");
把异常给抛出来了,上面抓到异常以后就会执行
我就是在工作中犯了此错误,
由于我在被调用方法catch的时候,给程序中的数据赋予,调用失败的状态,结果异常又被调用方给捕获,然后调用方的catch又将数据状态改为未知异常,影响了结果的判断
最终我将调用方代码合并上去,然后多做了一个捕获
public static void main(String[] args) { try{ int a = 100 / 0; }catch (RuntimeException e){ System.out.println("运行异常 RuntimeException 异常信息为:"+e); throw new RuntimeException(e); }catch (Exception e){ System.out.println("运行异常 Exception 异常信息为:"+e); } }
这次只运行了RuntimeException 的catch 尽管异常已经抛出,但是Exception 的catch依旧是没有执行