解决Java包装类比较时遇到的问题

网友投稿 411 2023-03-29


解决Java包装类比较时遇到的问题

前言

本文主要给大家介绍了关于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方法时要注意类型相同,或者直接用基础数据类型比较。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:深入浅析hbase的优点
下一篇:深入理解React高阶组件
相关文章

 发表评论

暂时没有评论,来抢沙发吧~