解决Java包装类比较时遇到的问题
前言
本文主要给大家介绍了关于Java包装类在比较时遇到的一些问题的解决方法,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。
例1:
Integera=1; Integerb=2; Integerc=3; Integerd=3; Integere=321; Integerf=321; Longg=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(Objectobject)中判断类型不符合,返回false。
例2:
Longa=1L; Integerb=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)时,int1装包成Integer,自然和Long不同类型。
publicbooleanequals(Objectobj){ if(objinstanceofLong){ returnvalue==((Long)obj).longValue(); } returnfalse; }
总结:
当使用自动拆包/装包时,包装类之间比较并不会自动拆包,是地址比较,其中还有缓存会影响结果。
用包装类的equals方式比较时,由于包装类并不会自动去转换类型,所以类型不同时,即使值相同,也会返回false。所以在用包装类比较数值时,不要用'==',用equals方法时要注意类型相同,或者直接用基础数据类型比较。
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。