java1.5之后提供的自动装箱和拆箱操作,简化了代码的编写,但是自动拆箱过程中容易引起nullPointExcetion。如果对其拆箱原理不理解将对很定位问题出现的原因。
原因:
例如如下代码:
public int findOrgIdByCode(String orgCode) {
return (Integer) super.queryForObject(DOMAIN_NAME_SPACE
+ "findOrgNameByCode", orgCode);
}
以上代码看似没有问题,但如果在sql语句查询为空时将会发生nullPointExcetion。
要了解发生异常的原因就需要知道拆箱的原理,拆箱是通过编译器完成的。上述代码的class文件通过反编译后代码如下:
public int findOrgIdByCode(String orgCode) {
return ((Integer) super.queryForObject(
"sys.DomainTree.findOrgIdByCode", orgCode)).intValue();
}
通过上述代码的对比就可以很容易看出问题出现的原因,自动拆箱是通过Integer.intValue()来实现的,所以当查询无数据时将会出现空指针异常。
解决办法:
了解了上述问题出现的原因后,当无法保证拆箱前的数据不为空时需要对该数据做非空判断来防止空指针的出现。将上述代码修改后:
public int findOrgIdByCode(String orgCode) {
Integer orgId = (Integer) super.queryForObject(DOMAIN_NAME_SPACE
+ "findOrgIdByCode", orgCode);
return null == orgId ? 0 : orgId;
}
该代码反编译后:
public int findOrgIdByCode(String orgCode) {
Integer orgId = (Integer) super.queryForObject(
"sys.DomainTree.findOrgIdByCode", orgCode);
return ((orgId == null) ? 0 : orgId.intValue());
}
经过上述处理后就不会发生空指针异常。
总结:
自动拆箱时(以Integer为例)调用包装类型的intValue()来进行拆箱,需要注意null.intValue()引起的空指针。