前几天有同学找我查一个空指针问题,Java 打印日志时,异常堆栈信息被吞了,导致定位不到出问题的地方。
现象
捕获异常打印日志的代码类似这样:
kotlin
复制代码
try { // ... } catch (Exception e) { log.error("系统异常 customerCode:{},data:{}", customerCode, data, e); // ... }
查到的日志是这样的:
kotlin
复制代码
2023-06-26 11:11:11.111 ERROR 1 --- [pool-1-thread-1] c.mazhuang.service.impl.TestServiceImpl : 系统异常 customerCode:123,data:{"name":"mazhuang","age":18} java.lang.NullPointerException: null
异常堆栈丢了。
分析
在之前的一篇文章里已经验证过这种写法是可以正常打印异常和堆栈信息的:AI 自动补全的这句日志能正常打印吗?
再三确认代码写法没问题,纳闷之下只好搜索了一下关键词「Java异常堆栈丢失」,发现了这篇文章:Java异常堆栈丢失的现象及解决方法,这里面提到的问题与我们遇到的一样,而且给出了 Oracle 官方文档里的相关说明: