三目运算符的坑
public static void main(String[] args) {
// 报错。三目运算符有个很隐蔽的操作,会把nullValue转换成跟 "-1L" 同样的类型,即原始类型(primitive type)。null值转原始类型自然出现NPE
Long nullValue = null;
Long l = true ? nullValue : -1L;
// 不报错。null不会被转为原始类型
Long l2 = true ? null : -1L;
// 不报错:nullValue可以转为跟 "new Long(-1)" 一样的类型,即包装类,而包装类允许null
Long l3 = true ? nullValue : new Long(-1);
}
解决
使用三目运算符,要考虑到两个选择的类型要一致,即flag ? value1 : value2
中的value1和value2的类型要相同,不要出现一个是包装类,一个是原始类型。如:
Long time = flag ? jo.getJSONObject("executeContext").getLong("executeTime") : -1L;
// 要改成
Long time = flag ? jo.getJSONObject("execute Context").getLong("executeTime") : new Long(-1);
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之家整理,本文链接:https://www.bmabk.com/index.php/post/135315.html