zoukankan      html  css  js  c++  java
  • NullPointerException异常没有异常栈打印问题追踪

    今天去服务器后台看日志,发现有很多NullPointerException异常。我下意识的找异常栈,想看下到底是哪行代码导致了空指针。但是发现日志中只打印出了如下日志:

    null
    java.lang.NullPointerException: null
    

    我怀疑是不是打印日志的时候是不是没有将异常栈打印出来,于是又去翻看源代码核实。但是发现日志打印也是正常的。

      logger.error(e.getMessage(),e);
    

    这就纳闷了,于是有怀疑是不是日志配置有问题。折腾了一番发现这些配置都没问题。一时没有了思路,只好去求助万能的百度。

    问题原因

    我在网上找到了这么一段描述:

    JVM虚拟机会对异常信息进行优化,当相同异常出现很多次,会认为它是热点异常,忽略掉异常堆栈信息;通过增加JVM参数:-XX:-OmitStackTraceInFastThrow可解决。

    这个描述能很好的解释我现在发现的问题。代码中出现空指针异常的地方是一个定时任务在不停地调用,当这个异常出现次数太多时JVM就会将其过滤掉。

    为了验证我的猜想,我去找了下这个服务刚刚启动时的代码,发现这个异常栈是正常打出的。验证了自己的猜想,通过异常栈也找到了导致空指针异常的代码。

    问题重现

    下面是自己写的一段代码来显示这个额问题:

    public class NullPointStackMissBug {
    
        static Logger logger = LoggerFactory.getLogger(NullPointStackMissBug.class);
    
        public static void main(String[] args) {
    
            for (int i = 0; i < 100000 ; i++) {
                try{
                    System.out.println("Loop:"+(i+1));
                    String str = "test";
                    if(true){
                        str = null;
                    }
                    str.toUpperCase();
                }catch (Exception e){
                    logger.error(e.getMessage(),e);
                }
            }
        }
    
    }
    

    在JVM启动参数中增加:-XX:-OmitStackTraceInFastThrow后,异常就能正常输出。

  • 相关阅读:
    This counter can increment, decrement or skip ahead by an arbitrary amount
    LUT4/MUXF5/MUXF6 logic : Multiplexer 8:1
    synthesisable VHDL for a fixed ratio frequency divider
    Bucket Brigade FIFO SRL16E ( VHDL )
    srl16e fifo verilog
    DualPort Block RAM with Two Write Ports and Bytewide Write Enable in ReadFirst Mode
    Parametrilayze based on SRL16 shift register FIFO
    stm32 spi sdcard fatfs
    SPI bus master for System09 (2)
    SQLSERVER中的自旋锁
  • 原文地址:https://www.cnblogs.com/54chensongxia/p/12930610.html
Copyright © 2011-2022 走看看