今天看到一个题,是这样的:
Integer i1=100;
Integer i2=100;
System.out.println(i1=i2);
Integer i3=1000;
Integer i4=1000;
System.out.println(i3=i4);
答案是什么呢?一个是true,一个是false。
解析一下:java的编译机制,会把代码先编译成(.class文件),但我们反编译看的时候,发现编译器把我们的代码变成了这样
Integer i1=Integer .valueOf(100);
Integer i2=Integer .valueOf(100);
System.out.println(i1=i2);
Integer i3=Integer .valueOf(1000);
Integer i4=Integer .valueOf(1000);
System.out.println(i3=i4);
我们再来看看valueOf的实现原理:
publick 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);不在缓存的数组里,直接new一个对象返回。
}
Integer的作者在写这个类的时候,为了避免重复对象,对integer做了缓存,如果这个值在缓存范围内,直接返回缓存好的对象,否则new一个新的对象
再看看IntegerCache这个类
这是一个内部静态类,该类只能在Integer这个类的内部访问,这个类在初始化的时候,会去加载JVM的配置,如果有值,就用配置的值初始化缓存数组,否则就缓存-128到127之间的值。
也就是说:
Integer i1=100; 给i1,i2赋值的时候在-128到127之间,取同一数组里的对象返回,i1,i2指
Integer i2=100; 向同一个对象,所以i1=i2,true
System.out.println(i1=i2);
Integer i3=1000;这里相当于new了两个新对象,所以false
Integer i4=1000;
System.out.println(i3=i4);