在某些情况下,Java 代码捕获 NullPointerException 但无法记录 StackTrace,让开发人员感到困惑,因为“显示java.lang.NullPointerException”。
这个令人困惑的问题让开发者在线寻找解决方案无果。然而,经过进一步调查,发现根本原因在于 HotSpot JVM 的优化策略。
为了抵消这种优化并恢复 StackTrace 检索,开发人员必须将以下参数传递给 JVM:
-XX:-OmitStackTraceInFastThrow
这种优化源于 JVM 对重复异常的处理,例如 NullPointerExceptions。首次发生时,JVM 会记录完整的 StackTrace。然而,在频繁发生的情况下,出于性能原因和避免过多的日志条目,JVM 会抑制 StackTrace 日志记录。
此实现的详细说明可以在 HotSpot JVM 源代码中找到,特别是在“graphKit.h”文件中。 cpp”文件。通过调整 OmitStackTraceInFastThrow 变量,开发人员可以重新获得堆栈跟踪可见性并促进调试过程。
以上是为什么 Java NullPointerException 缺少 StackTrace?的详细内容。更多信息请关注PHP中文网其他相关文章!