明天遇到一个奇怪的Java三元表达式中的空指针异样。特此记录。

代码

代码示意如下:

Integer itemVO = null;Integer globleLatenessToleranceUseAlternate = null;Integer latenessToleranceUseAlternate =    (itemVO == null ? globleLatenessToleranceUseAlternate : itemVO.intValue());

从下面代码能够看出:当itemVO不为空时,就取itemVO的值;否则,就取globleLatenessToleranceUseAlternate的值。

起因

但问题就在globleLatenessToleranceUseAlternate。当itemVO为空时,如果取globleLatenessToleranceUseAlternate,并不会失去值null, 而是Java会把globleLatenessToleranceUseAlternate进行一个主动开箱拆箱解决。简言之,获得是 globleLatenessToleranceUseAlternate.intValue(), 此时,因为globleLatenessToleranceUseAlternate 自身是 null,因而 globleLatenessToleranceUseAlternate.intValue() 导致了空指针因而。

解法

批改如下解决:

Integer itemVO = null;Integer globleLatenessToleranceUseAlternate = null;Integer latenessToleranceUseAlternate;if (itemVO != null) {    latenessToleranceUseAlternate = itemVO.intValue();} else {    latenessToleranceUseAlternate = globleLatenessToleranceUseAlternate;}

值得注意的是,在新版的JDK和Eclipse中,会做出敌对的提醒,从而可能无效躲避上述问题。提醒如下:

Null pointer access: This expression of type Integer is null but requires auto-unboxing
起源:https://waylau.com/trap-in-ja...
欢送关注公众号 【码农开花】一起学习成长
我会始终分享Java干货,也会分享收费的学习材料课程和面试宝典
回复:【计算机】【设计模式】【面试】有惊喜哦