Integer自动拆箱遇到的一个坑

代码大致如下:

    class test{
        private Integer num;
        private Integer sum;

        public Integer getNum() {
            return num;
        }

        public void setNum(Integer num) {
            this.num = num;
        }

        public Integer getSum() {
            return sum;
        }

        public void setSum(Integer sum) {
            this.sum = sum;
        }
    }

    Integer a = 1;
    Integer b = new Test().getNum();
    if(a.intValue() == b){
        system.out.println("相等");
    }

这是今天遇到的一个bug,具体代码比这个复杂,实际操作是把权限从数据库读取然后把没有关闭的菜单返回到前端,是否关闭用的Integer,类似于上面代码中的Test类中的num属性,然后对比是否为1,其实这里我也不知道a.inValue()是一种什么骚操作,反正写这段代码的大佬就是这么写的,然后就非常诡异的空指针java.lang.NullPointerException,因为这段代码是递归,然后又各种判断,而且还家里几个for循环,并且对比的操作也和另外两个条件一起在if里面,反正就是由于大佬的各种神操作,我硬是没有看出到底怎么导致的空指针,最终debug了将近半个小时,才知道是在这个if判断里面出现的异常。然后看到了这个对比的骚操作,

原因:a.intValue()返回int,判断相等会自动调用b的intValue函数,b是null,所以就抛出了空指针

然后我改成Integer的equals对比,用equals时,要把确定有值的对象放在前面,即a.equals(b);

猜你喜欢

转载自blog.csdn.net/qq_34101608/article/details/80489654
今日推荐