Em alguns casos, o código Java captura um NullPointerException, mas não consegue registrar um StackTrace, deixando os desenvolvedores perplexos como apenas " java.lang.NullPointerException" é exibido.
Esse problema desconcertante deixou os desenvolvedores em busca de soluções on-line sem sucesso. No entanto, após uma investigação mais aprofundada, descobriu-se que a causa raiz está nas estratégias de otimização do HotSpot JVM.
Para neutralizar essa otimização e restaurar a recuperação do StackTrace, os desenvolvedores devem passar o seguinte argumento para a JVM:
-XX:-OmitStackTraceInFastThrow
Essa otimização decorre do tratamento de exceções repetitivas pela JVM, como NullPointerExceptions. Na ocorrência inicial, a JVM registra o StackTrace completo. No entanto, com ocorrências frequentes, a JVM suprime o log do StackTrace por motivos de desempenho e para evitar entradas de log excessivas.
Uma explicação detalhada desta implementação pode ser encontrada no código-fonte da JVM do HotSpot, especificamente no "graphKit. cpp" arquivo. Ao ajustar a variável OmitStackTraceInFastThrow, os desenvolvedores podem recuperar a visibilidade do rastreamento de pilha e facilitar os processos de depuração.
Isenção de responsabilidade: Todos os recursos fornecidos são parcialmente provenientes da Internet. Se houver qualquer violação de seus direitos autorais ou outros direitos e interesses, explique os motivos detalhados e forneça prova de direitos autorais ou direitos e interesses e envie-a para o e-mail: [email protected]. Nós cuidaremos disso para você o mais rápido possível.
Copyright© 2022 湘ICP备2022001581号-3