Maison >Java >javaDidacticiel >Comment obtenir des traces de pile pour les exceptions NullPointerExceptions lorsque l'optimisation les gêne ?
Lors du traitement des exceptions NullPointerException en Java, les développeurs peuvent rencontrer des situations dans lesquelles la trace de pile est totalement absente, ce qui rend la tâche difficile pour retracer la source de l'exception.
En général, lorsqu'une NullPointerException est levée, sa trace de pile fournit des informations précieuses sur le chemin du code incriminé. Cependant, certaines optimisations effectuées par la JVM HotSpot peuvent supprimer ces traces de pile.
Pour récupérer les traces de pile, l'option suivante doit être passée à la JVM :
-XX:-OmitStackTraceInFastThrow
Cette option demande à la JVM de s'abstenir d'optimiser la gestion des NullPointerExceptions, en garantissant que les traces de pile sont imprimées pour chaque occurrence de l'exception.
Le HotSpot JVM utilise une technique d'optimisation qui met en cache les traces de pile pour les exceptions fréquentes, en particulier les NullPointerExceptions. Cette optimisation vise à améliorer les performances et à éviter une journalisation excessive de traces de pile identiques.
Dans la JVM HotSpot, cette optimisation est implémentée dans le fichier graphKit.cpp. Cela implique une variable globale nommée OmitStackTraceInFastThrow, qui contrôle la suppression des traces de pile.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!