使用“==”比较两个数值相等的Integer类型整数(“==”比较的是地址值),我们会发现返回值有时为true,有时为false。
例如:
Integer i1 = 128;
Integer i2 = 128;
System.out.println(i1 == i2); //输出结果:false
Integer i3 = 127;
Integer i4 = 127;
System.out.println(i3 == i4); //输出结果:true
为什么出现这种情况:
因为Integer i1 = 128; 这种方式会自动装箱:底层调用的是 Integer.valueOf(128); 来装的箱。那我们先来看一下valueOf的源码:
public static Integer valueOf(int i) {
if (i >= IntegerCache.low && i <= IntegerCache.high)
return IntegerCache.cache[i + (-IntegerCache.low)];
return new Integer(i);
}
IntegerCache源码:
private static class IntegerCache {
static final int low = -128;
static final int high;
static final Integer cache[];
static {
// high value may be configured by property
int h = 127;
String integerCacheHighPropValue =
sun.misc.VM.getSavedProperty("java.lang.Integer.IntegerCache.high");
if (integerCacheHighPropValue != null) {
try {
int i = parseInt(integerCacheHighPropValue);
i = Math.max(i, 127);
// Maximum array size is Integer.MAX_VALUE
h = Math.min(i, Integer.MAX_VALUE - (-low) -1);
} catch( NumberFormatException nfe) {
// If the property cannot be parsed into an int, ignore it.
}
}
high = h;
cache = new Integer[(high - low) + 1];
int j = low;
for(int k = 0; k < cache.length; k++)
cache[k] = new Integer(j++);
// range [-128, 127] must be interned (JLS7 5.1.7)
assert IntegerCache.high >= 127;
}
private IntegerCache() {}
}
通过valueOf的源码就知道了,i>=IntegerCache.low&&i<=IntegerCache.high的时候,从IntegerCache中获取的实例,否则,直接new Integer(i);
low就是-128,high是默认的127,不过可以进行设置;
通过静态代码块直接创建了256个Integer的对象,从-128到127之间的整数都实例化了,所以不管创建多少这个范围的Integer都是同一个对象。
而超出这个范围会创建新的Integer对象 ,因此地址值也不同。