【记录】低级错误---if判断语句中的空指针异常

异常

1.今天在判断一个参数的时候不断触发空指针异常,检查发现代码问题出在这一段

if (feedBackPageDTO.getCityId()!=0 && feedBackPageDTO.getCityId()!=null) {
            qw.eq("city_id", feedBackPageDTO.getCityId());
}

2.但是试着将feedBackPageDTO.getCityId()!=0 && feedBackPageDTO.getCityId()!=null的顺序交换,就不会出现这个错误。在我看来,这两个逻辑条件是独立于彼此的,交换顺序并不会有什么影响。

解惑

在这里feedBackPageDTO类中cityId是Integer类型,所以feedBackPageDTO.getCityId()返回的也是一个Integer类型的值,而不是基本数据类型 int,那么先执行feedBackPageDTO.getCityId() != null 可以避免在比较之前出现空指针异常;而将 feedBackPageDTO.getCityId() != 0 放在前面,则可能触发空指针异常。

Java中一个空引用调用了实例方法或访问实例字段就会触发空指针异常,因此在一个可能为null的数据的时候最好先比较这个数据是否!=null,避免触发空指针异常。

在给定的情况下,假设 feedBackPageDTO.getCityId() 返回的是一个装箱后的 Integer 对象。如果将 feedBackPageDTO.getCityId() != 0 放在前面,那么当 feedBackPageDTO.getCityId() 为null时,代码会尝试在null引用上调用 .intValue() 方法进行比较,而这将导致空指针异常。

但是,如果我们先执行 feedBackPageDTO.getCityId() != null 的判断,当 feedBackPageDTO.getCityId() 为null时,条件判断为false,不会继续执行后面的逻辑判断,也就可以避免了在null引用上调用 .intValue() 方法的问题,从而避免了空指针异常。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值