代码大致如下:
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);