行业资讯 2025年08月6日
0 收藏 0 点赞 975 浏览 819 个字
摘要 :

文章目录 原因分析 解决办法 总结 Java项目新功能(定时任务)上线发现抛java.lang.ArrayIndexOutofBoundsException:null,奇怪的是log.error只打印了异常名称却没有打……




  • 原因分析
  • 解决办法
  • 总结

Java项目新功能(定时任务)上线发现抛java.lang.ArrayIndexOutofBoundsException:null,奇怪的是log.error打印异常名称却没有打印Java异常堆栈信息,想知道哪行代码报的错都找不到,这是怎么回事?又该怎么办?我们先看下具体情况如下图:Java异常堆栈信息没打印出来怎么回事,怎么办?

首先我们使用的是如下代码打印的错误日志:

public void handle() {
        try {
            this.start();
        }catch (Exception e) {
            log.error(\"handle exception\", e);
        }
}

log.error是肯定没有问题的,因为之前这么用都 没出问题,只有这次不打印堆栈异常信息了。

原因分析

JVM(Java虚拟机)的JIT(即时编译器)会对某些异常进行称为”fast throw”的优化,专门针对在同一个方法中多次抛出相同异常堆栈的情况下(我这里就是因为定时任务一直抛异常导致的)。JIT编译器可能会优化这些异常,以提高性能。在这种情况下,通过直接抛出一个预分配好的、类型匹配的异常对象来避免重新构建异常对象和填充堆栈信息(即抛出一个不带堆栈信息的异常),以减少开销。

针对的异常如下:

  • NullPointerException
  • ArithmeticException
  • ArrayIndexOutOfBoundsException
  • ArrayStoreException
  • ClassCastException

解决办法

1)如果要看具体的该异常的堆栈信息内容,可以追溯刚开始报错的日志查看。

2)强制禁用此优化,只需要在启动jar包时在,启动参数加上如下参数指令:

-XX:-OmitStackTraceInFastThrow

这样就可以强制打印Java异常堆栈信息,当然这会造成损耗系统性能并且日志文件过大的问题。

总结

以上就是Java异常堆栈信息没打印出来是怎么回事,以及我们怎么办的问题全部内容,希望对你有帮助!

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/9277.html

管理员

相关推荐
2025-08-06

文章目录 一、Reader 接口概述 1.1 什么是 Reader 接口? 1.2 Reader 与 InputStream 的区别 1.3 …

988
2025-08-06

文章目录 一、事件溯源 (一)核心概念 (二)Kafka与Golang的优势 (三)完整代码实现 二、命令…

465
2025-08-06

文章目录 一、证明GC期间执行native函数的线程仍在运行 二、native线程操作Java对象的影响及处理方…

348
2025-08-06

文章目录 一、事务基础概念 二、MyBatis事务管理机制 (一)JDBC原生事务管理(JdbcTransaction)…

456
2025-08-06

文章目录 一、SnowFlake算法核心原理 二、SnowFlake算法工作流程详解 三、SnowFlake算法的Java代码…

517
2025-08-06

文章目录 一、本地Jar包的加载操作 二、本地Class的加载方法 三、远程Jar包的加载方式 你知道Groo…

832
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号