作者:手机用户2502891985 | 来源:互联网 | 2023-05-17 08:34
我们都知道用来比较两个对象是否相同,比较是引用,即两边是否指向同一个对象,如果是同一个对象的引用,则返回true,否则返回false。但是我们通常在比较Integer时,忘记它是一
我们都知道 用 ==来比较两个对象是否相同,比较是引用,即 == 两边是否指向同一个对象,如果是同一个对象的引用,则返回true,否则返回false。
但是我们通常在比较Integer时,忘记它是一个对象
这是由于在Integer的源码实现中,Integer 把-128-127 之间的每个值都建立了一个对应的Integer 对象放入了一个数组中,这里的数组类似于缓存,提前给你准备好这个范围内的对象。由于Integer 是不可变类,因此这些缓存的Integer 对象可以安全的重复使用。
public static void main(String[] args)
{
Integer n1 = new Integer(47);
Integer n2 = new Integer(47);
Integer n3 = 47;
Integer n4 = 47 ;
Integer n5 = 200;
Integer n6 = 200;
System.out.println(n1 == n2);
System.out.print(n2 == n3);
System.out.print(",");
System.out.println(n3 == n4);
System.out.println(n5 == n6);
int i=0;
Integer j = new Integer(0);
System.out.println(i==j);
System.out.println(j.equals(i));
}
结论:
我们可以认为,在源码中Interger已经事先开辟了值在-128~127的范围内的Interger对象数组,如果使用new出来的Integer对象,尽管大小在这之间,也是和源码内的缓存数组不同,所以==会是false;
但是直接使用 Interger a = 40;那么这个a就是指向缓存数组的,==会起到equals的效果,因为它们指向同一个对象,当超出这个范围时,== 就会出错了。
本题是一个自动拆装箱的考题(自动拆装箱JDK需在1.5上)
1、基本型和基本型封装型进行“==”运算符的比较,基本型封装型将会自动拆箱变为基本型后再进行比较,因此Integer(0)会自动拆箱为int类型再进行比较,显然返回true;
2、两个Integer类型进行“==”比较,如果其值在-128至127,那么返回true,否则返回false, 这跟Integer.valueOf()的缓冲对象有关,这里不进行赘述。
3、两个基本型的封装型进行equals()比较,首先equals()会比较类型,如果类型相同,则继续比较值,如果值也相同,返回true
4、基本型封装类型调用equals(),但是参数是基本类型,这时候,先会进行自动装箱,基本型转换为其封装类型,再进行3中的比较。