明天遇到一个奇怪的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干货,也会分享收费的学习材料课程和面试宝典
回复:【计算机】【设计模式】【面试】有惊喜哦