Java 异常体系

异常处理机制主要回答了三个问题

  • What:异常类型回答了什么被抛出
  • Where:异常堆栈跟踪回答了在哪抛出
  • Why:异常信息回答了为什么被抛出

异常体系

截屏2021-01-28 上午11.32.37

Error和Exception的区别

从概念角度解析java异常处理机制

  • Error:程序无法处理的系统错误,编译器不做检查
    • 一般是与Jvm相关的问题,如系统崩快,内存不住,stackOverFlow等
    • 仅靠程序本身无法恢复
  • Exception:程序可以处理的异常,捕获后可以恢复

总结:前者是程序无法处理的错误,后者是可以处理的错误。

Exception:

  • RuntimeException:不可预知,程序应该自行避免
    • 如访问空指针,数组下标越界,除0
  • 非RuntimeException:可预知的,从编译器校验的异常
    • 如文件不存在而打开文件失败

从责任的角度

  • Error属于JVM需要承担的责任
  • RuntimeException是程序应该负担的责任
  • Checked Exception可检查异常是Java编译器应该负担的责任

常见Error及Exception

截屏2021-01-28 上午11.45.26 截屏2021-01-28 上午11.47.04

异常处理机制

  • 抛出异常:创建异常对象,交由运行时系统处理。
  • 捕获异常:寻找合适的异常处理器处理异常,否则终止运行。
    • 依次调用栈中的方法,如果不符合此异常则下一个。

异常处理原则

截屏2021-01-28 下午12.13.11

设计一个高效主流的异常处理框架

在用户看来,应用系统发生的所有异常都是应用系统内部的异常

  • 设计一个通用的继承自RuntimeException的异常来统一处理
  • 其余异常都统一转译为上述自定义的异常
  • 在catch后,抛出自定义异常的子类,并提供足以定位的信息。
  • 由前端接收自定义异常做统一处理

示例:

截屏2021-01-28 下午12.17.55

try-catch的性能

Java异常处理消耗性能的地方:

  • try-catch块影响JVM的优化。
  • 异常对象实例需要保存栈快照信息等,开销较大。