代码样例:
int i = 128;
Integer i2 = 128;
Integer i3 = new Integer(128);
// Integer会自动拆箱为int,所以为true
System.out.println(i == i2); //java在编译的时候,被翻译成-> i == i2.intValue()
System.out.println(i == i3);
Integer i5 = 127;// java在编译的时候,被翻译成-> Integer i5 = Integer.valueOf(127);
Integer i6 = 127;
System.out.println(i5 == i6);// true
//Integer i5 = 128; Integer i6 = 128; System.out.println(i5 ==i6);//false
Integer ii5 = new Integer(127);
System.out.println(i5 == ii5); // false
Integer i7 = new Integer(128);
Integer i8 = new Integer(123);
System.out.println(i7 == i8); // false
java在编译Integer i5 = 127的时候,被翻译成-> Integer i5 = Integer.valueOf(127);JDK源码的valueOf函数式这样的:
public static Integer valueOf(int i) {
assert IntegerCache.high >= 127;
if (i >= IntegerCache.low && i <= IntegerCache.high)
return IntegerCache.cache[i + (-IntegerCache.low)];
return new Integer(i);
}
总结:
①无论如何,Integer与new Integer(i)相比都不会相等,不会经历拆箱过程。new Integer(i)的引用指向堆。而Integer如果范围在-128到127之间,指向专门存放他的内存(常量池),不在-128到127之间,会新产生一个对象(在堆里面)。只要新new对象,内存地址肯定不一样,所以为false
②两个都是非new出来的Integer,在比较的时候,会调用Integer.valueOf(int i)。如果数在-128到127之间,则是true(因为他们放在常量池里面),否则为false(都是返回new Integer(i))
java在编译Integer i2 = 128的时候,被翻译成-> Integer i2 = Integer.valueOf(128);而valueOf()函数只会对-128到127之间的数进行缓存
③两个都是new出来的,都为false
④int和Integer(无论是否new)比,都为true,因为会把Integer自动拆箱(编译的时候都会调用i.intValue())为int再去比