Java 包装类比较时带来的问题(待验证)

1:

        Integer a = 1;
        Integer b = 2;
        Integer c = 3;
        Integer d = 3;
        Integer e= 321;
        Integer f= 321;
        Long g = 3L;
        System.out.println(c == d); //1
        System.out.println(e == f); //2
        System.out.println(c == (a+b)); //3 
        System.out.println(c.equals(a+b));//4
        System.out.println(g == (a+b)); //5
        System.out.println(g.equals(a+b)); //6
输出结果

true
false
true
true
true
false
1.包装类比较,不会自动拆包,但是Integer中会有一个cache 存储-128127的数,所以c与d的地址值相同。
2.地址值比较,没用到cache
3.'=='时,右侧发生自动拆包,所以其实是int值在比较
4.a+b 时拆包成int,传入Integer的equals方法进行自动装包。equals方法内是值比较。
5.会拆包成基础数据类型比较
6.包装类的equals 会判断类型,Long.equals(Object object)中判断类型不符合,返回false。

例2:

        Long a = 1L;
        Integer b = 1;
        System.out.println(a.equals(1)); //7
        System.out.println(a.equals(1L));
        System.out.println(a.equals(b));
输出

false
true
false
看包装类源码会发现比较时会先去判断类型是否相同。
7.a.equals(1)时,int 1 装包成Integer,自然和Long不同类型。

 public boolean equals(Object obj) {
        if (obj instanceof Long) {
            return value == ((Long)obj).longValue();
        }
        return false;
    }
总结:
当使用自动拆包/装包时,包装类之间比较并不会自动拆包,是地址比较,其中还有缓存会影响结果。
用包装类的equals方式比较时,由于包装类并不会自动去转换类型,所以类型不同时,即使值相同,也会返回false。所以在用包装类比较数值时,不要用'==',用equals方法时要注意类型相同,或者直接用基础数据类型比较。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值