java整型比较大小使用“==”引发的血案

目录

背景

原因(方法使用错误)

代码

原码解析

建议


背景

      某个开发小哥哥开发了一段代码,比较2个Long类型的,用了符号“==”;开发自己测试后移交给测试在不同的环境测试后无问题,然后上线;刚上线生产大量报错,代码回滚,然后开始抓鬼.........
 

原因(方法使用错误)

        造成以上问题且多方测试均未发现问题的原因主要是:
       ① 使用基本类型的包装类隐式定义变量 (例如:Integer a = 5;)
       ② 使用比较符==比价变量大小  
       ③ 测试数值范围小,且在【-128~127】区间
 
        总的来讲还是对基本数据类型比较大小的使用方法的不规范(==比价的是物理地址)
Byte、Short、Integer、Long隐式定义变量时;例如:Integer a = 8,会使用Integer的“public static Integer valueOf(int i)”方法完成基本数据类型的装箱,然而......
  • 为了空间和时间的性能,此方法会对经常请求的值【-128~127】缓存到IntegerCache;
  •  不同的对用如果定义的变量相同且均大小在缓存的区间时,对象的引用地址指向了同一个缓存即具备同一个物理地址;
  • “==”比较的是2个对象的内存地址是否相等;当测试数据太小在缓存区间时,用“==”比较结果相等,造成一定的假象;
 

代码

@Test
public void testIntCache() {
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值