In einigen Fällen fängt Java-Code eine NullPointerException ab, protokolliert jedoch keinen StackTrace, was die Entwickler verwirrt, da nur „ java.lang.NullPointerException“ wird angezeigt.
Dieses verwirrende Problem hat dazu geführt, dass Entwickler erfolglos online nach Lösungen gesucht haben. Bei weiteren Untersuchungen wurde jedoch festgestellt, dass die Ursache in den Optimierungsstrategien der HotSpot-JVM liegt.
Um dieser Optimierung entgegenzuwirken und den StackTrace-Abruf wiederherzustellen, müssen Entwickler das folgende Argument an die JVM übergeben:
-XX:-OmitStackTraceInFastThrow
Diese Optimierung ergibt sich aus der Behandlung sich wiederholender Ausnahmen wie NullPointerExceptions durch die JVM. Beim ersten Auftreten protokolliert die JVM den gesamten StackTrace. Bei häufigen Vorkommnissen unterdrückt die JVM jedoch die StackTrace-Protokollierung sowohl aus Leistungsgründen als auch zur Vermeidung übermäßiger Protokolleinträge.
Eine ausführliche Erläuterung dieser Implementierung finden Sie im HotSpot-JVM-Quellcode, insbesondere im „graphKit. cpp“-Datei. Durch Anpassen der OmitStackTraceInFastThrow-Variable können Entwickler die Stack-Trace-Sichtbarkeit wiederherstellen und Debugging-Prozesse erleichtern.
Das obige ist der detaillierte Inhalt vonWarum fehlen Java NullPointerExceptions StackTraces?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!