Java项目新功能(定时任务)上线发现抛
java.lang.ArrayIndexOutofBoundsException:null,奇怪的是log.error只打印了异常名称却没有打印Java异常堆栈信息,想知道哪行代码报的错都找不到,这是怎么回事?又该怎么办?我们先看下具体情况如下图:
首先我们使用的是如下代码打印的错误日志:
public void handle() {
try {
this.start();
}catch (Exception e) {
log.error("handle exception", e);
}
}
log.error是肯定没有问题的,因为之前这么用都 没出问题,只有这次不打印堆栈异常信息了。
原因分析
JVM(Java虚拟机)的JIT(即时编译器)会对某些异常进行称为”fast throw”的优化,专门针对在同一个方法中多次抛出相同异常堆栈的情况下(我这里就是因为定时任务一直抛异常导致的)。JIT编译器可能会优化这些异常,以提高性能。在这种情况下,通过直接抛出一个预分配好的、类型匹配的异常对象来避免重新构建异常对象和填充堆栈信息(即抛出一个不带堆栈信息的异常),以减少开销。

程序员导航
优网导航旗下整合全网优质开发资源,一站式IT编程学习与工具大全网站
针对的异常如下:
- NullPointerException
- ArithmeticException
- ArrayIndexOutOfBoundsException
- ArrayStoreException
- ClassCastException
解决办法
1)如果要看具体的该异常的堆栈信息内容,可以追溯刚开始报错的日志查看。
2)强制禁用此优化,只需要在启动jar包时在,启动参数加上如下参数指令:
-XX:-OmitStackTraceInFastThrow
这样就可以强制打印Java异常堆栈信息,当然这会造成损耗系统性能并且日志文件过大的问题。

AI 工具导航
优网导航旗下AI工具导航,精选全球千款优质 AI 工具集
总结
以上就是Java异常堆栈信息没打印出来是怎么回事,以及我们怎么办的问题全部内容,希望对你有帮助!
© 版权声明
文章版权归作者所有,未经允许请勿转载。
相关文章
暂无评论...



