어떤 경우에는 Java 코드가 NullPointerException을 포착하지만 StackTrace를 기록하지 못하여 개발자는 " java.lang.NullPointerException"이 표시됩니다.
이 당황스러운 문제로 인해 개발자는 온라인에서 솔루션을 검색해도 소용이 없었습니다. 그러나 추가 조사 결과 근본 원인은 HotSpot JVM의 최적화 전략에 있는 것으로 밝혀졌습니다.
이 최적화에 대응하고 StackTrace 검색을 복원하려면 개발자는 다음 인수를 JVM에 전달해야 합니다.
-XX:-OmitStackTraceInFastThrow
이 최적화는 JVM이 NullPointerException과 같은 반복적인 예외를 처리하는 데서 비롯됩니다. 처음 발생하면 JVM은 전체 StackTrace를 기록합니다. 그러나 자주 발생하는 경우 JVM은 성능상의 이유와 과도한 로그 항목을 피하기 위해 StackTrace 로깅을 억제합니다.
이 구현에 대한 자세한 설명은 HotSpot JVM 소스 코드, 특히 "graphKit. cpp" 파일입니다. OmitStackTraceInFastThrow 변수를 조정함으로써 개발자는 스택 추적 가시성을 다시 얻고 디버깅 프로세스를 촉진할 수 있습니다.
위 내용은 Java NullPointerException에 StackTrace가 누락되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!