异常体系
从责任角度看
- Error属于JVM需要负担的责任
- RuntimeException是程序应该承担的责任
- Checked Exception可检查异常是Java编译器应该承担的责任
- Error和Exception的区别
- Error:程序无法处理的系统的错误,编译器不做检查;程序无法处理的错误
- Exception:程序可以处理的异常,补货后可能恢复;程序可以处理的错误
- 常见Error以及Exception
RuntimeException
- NullPointerException–空指针引用异常(调用空对象)
- ClassCastException–类型强制转换异常
- IllegalArgumentException–传递非法参数异常(传参类型,个数不符)
- IndexOutOfBoundsException–下标越界异常
- NumberFormatException–数据格式异常
非RuntimeException
- ClassNotFoundException–找不到指定class的异常
- IOException–IO操作异常
Error
- NoClassDefFoundError–找不到class定义的异常(成因:1. 类依赖的class或jar不存在 2. 类文件存在,但是存在不同的域中 3. 大小写问题,javac编译的时候是无视大小写的,很有可能编译出来的class文件与想要的不一样)
- StackOverflowError–深递归导致栈被耗尽而抛出的异常
- OutOfMemoryError–内存溢出异常
异常处理机制
- 抛出异常:创建异常对象,交由运行时系统处理
- 捕获异常:寻找合适的异常处理器处理异常,否则终止运行
高效的异常处理框架
- 设计一个通用的继承自RuntimeException的异常来同一处理
- 其余异常都统一转译为上述异常AppException
- 在catch之后,抛出上述异常的子类,并提供足以定位的信息
Java异常处理消耗性能的地方
- try-catch块影响JVM的优化
- 异常对象实例需要保存栈快照等信息,开销较大