java三元运算符的空指针NPE问题

线上代码发现一个问题,下面的代码会抛出空指针异常。

JSONObject timeZone = getTimeZone();
Long sign = null == timeZone? 8L : getSign(timeZone);

上述功能比较简单,根据传入的JSONObject获取UTC时区的偏移量,如果没有获取到,就返回北京时间默认的东八区偏移8L;

在getSign方法内部,会对timeZone进行处理,核心代码可以简短描述为

Long getSign(JSONObject timeZone) {
  // 当满足某些场景时,直接返回偏移量
  if (timeZone.containsKey("sign")){
    return timeZone.getLong("sign");
  }
  // 其他情况下,直接返回null
  return null;
}

问题出现在三元运算符,当三元运算符的右侧,发现8L:getSign两个操作时,会统一将其转为基本类型,也就是long。这就会涉及到基本类型的拆箱操作,如果getSign的返回结果为null,就会触发NPE。

测试代码如下:

public static void main(String[] args) {
  Long result = null == args? 8L : getSign(args);
  System.out.println(result);
}

private static Long getSign(String[] args) {
  if (null == args || args.length == 0) {
    return null;
  }
  return Long.valueOf(args[0]);
}

通过查看class文件 javap -c ,如下图

image-20210228221019707

标红的代码也就是拆箱操作,所以会触发NPE。

针对该问题,最简单的可以采用以下方式:

JSONObject timeZone = getTimeZone();
Long defaultSign = 8L;
Long sign = null == timeZone? defaultSign : getSign(timeZone);

所以,使用三元运算符时,一定要注意类似的问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

51iwowo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值