Java 包装类比较时带来的问题

发布时间:2019-11-19 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了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 存储-128到127的数,所以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方法时要注意类型相同,或者直接用基础数据类型比较。

脚本宝典总结

以上是脚本宝典为你收集整理的Java 包装类比较时带来的问题全部内容,希望文章能够帮你解决Java 包装类比较时带来的问题所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。