JVM 在创建一个Throwable 类及其子类时会把当前线程的栈信息记录下来,以便在输出异常时准确定位异常原因,Throwable 部分源码如下:
- public class Throwable implements Serializable {
- // 出现异常的栈记录
- private StackTraceElement[] stackTrace;
- // 默认构造器
- public Throwable() {
- // 记录栈帧
- fillInStackTrace();
- }
- // 本地方法,抓取执行时栈信息
- public synchronized native Throwable fillInStackTrace();
- }
在出现异常时(或主动声明一个 Throwable 对象时),JVM 会通过 fillInStackTrace 方法记录下栈帧信息,然后生成一个 Throwable 对象。fillInStackTrace 方法记录异常时的栈信息是个非常耗时的动作,如果我们在开发时不需要关注栈信息,则可以将其覆盖,如下覆盖 fillInStackTrace 的自定义异常会使性能提升 10 倍以上:
- class MyException extends Exception {
- public Throwable fillInStackTrace() {
- return this;
- }
- }