Integer i = 42;
Long l = 42l;
Double d = 42.0;
下面为true的是
(i == l)=》false
(i == d)=》false
(l == d)=》false
i.equals(d)=》false
d.equals(l)=》false
i.equals(l)=》false
l.equals(42L)=》true
0,基本型比较,低精度向高精度自动补齐在进行比较。
1、基本型和基本型封装型进行“==”运算符的比较,基本型封装型将会自动拆箱变为基本型后再进行比较,因此Integer(0)会自动拆箱为int类型再进行比较,显然返回true;
2、两个Integer类型进行“==”比较,如果其值在-128至127,那么返回true。其他两种包装类进行比较,返回false, 这跟Integer.valueOf()的缓冲对象有关,这里不进行赘述。两个引用比较其地址。
3、两个基本型的封装型进行equals()比较,首先equals()会比较类型,不同false;如果类型相同,则继续比较值,如果值也相同,返回true
4、基本型封装类型调用equals(),但是参数是基本类型,这时候,先会进行自动装箱,基本型转换为其封装类型,再进行3中的比较。
如果有Integer i=new Integer(4);
那么 i代表的是一个地址,在==中是以地址出现,所以一般为false。equels()不影响。
————————————————
版权声明:本文为CSDN博主「征路遥」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_35226571/article/details/78465442