어떤 경우에는 Java 코드가 NullPointerException을 포착하지만 StackTrace를 기록하지 못하여 개발자는 " java.lang.NullPointerException"가 표시됩니다.
이 당황스러운 문제로 인해 개발자는 온라인에서 솔루션을 검색해도 소용이 없었습니다. 그러나 추가 조사를 통해 근본 원인이 HotSpot JVM의 최적화 전략에 있다는 사실이 밝혀졌습니다.
이 최적화에 대응하고 StackTrace 검색을 복원하려면 개발자는 다음 인수를 JVM에 전달해야 합니다.
-XX:-OmitStackTraceInFastThrow
이 최적화는 NullPointerException과 같은 JVM의 반복적 예외 처리에서 비롯됩니다. 처음 발생하면 JVM은 전체 StackTrace를 기록합니다. 그러나 자주 발생하는 경우 JVM은 성능상의 이유와 과도한 로그 항목을 피하기 위해 StackTrace 로깅을 억제합니다.
이 구현에 대한 자세한 설명은 HotSpot JVM 소스 코드, 특히 "graphKit. cpp" 파일입니다. OmitStackTraceInFastThrow 변수를 조정함으로써 개발자는 스택 추적 가시성을 다시 얻고 디버깅 프로세스를 촉진할 수 있습니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3