在某些情况下,Java 代码捕获 NullPointerException 但无法记录 StackTrace,这让开发人员感到困惑,因为“显示“java.lang.NullPointerException”。
这个令人费解的问题让开发者在网上寻找解决方案无果。然而,经过进一步调查,发现根本原因在于 HotSpot JVM 的优化策略。
为了抵消这种优化并恢复 StackTrace 检索,开发人员必须将以下参数传递给 JVM:
-XX:-OmitStackTraceInFastThrow
这种优化源于JVM对重复异常的处理,例如NullPointerExceptions。首次发生时,JVM 会记录完整的 StackTrace。然而,在频繁发生的情况下,出于性能原因和避免过多的日志条目,JVM 会抑制 StackTrace 日志记录。
此实现的详细说明可以在 HotSpot JVM 源代码中找到,特别是在“graphKit.h”文件中。 cpp”文件。通过调整 OmitStackTraceInFastThrow 变量,开发人员可以重新获得堆栈跟踪可见性并促进调试过程。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3