1. 调用Integer.valueOf()时, 对[-128,127]进行了缓存!
public final class Integer extends Number implements Comparable<Integer> { private static class IntegerCache { private IntegerCache(){} static final Integer cache[] = new Integer[-(-128) + 127 + 1]; static { for(int i = 0; i < cache.length; i++) cache[i] = new Integer(i - 128); } } public static Integer valueOf(int i) { final int offset = 128; if (i >= -128 && i <= 127) { // must cache return IntegerCache.cache[i + offset]; } return new Integer(i); } }
2. 装箱与拆箱的本质:
装箱: 自动Integer.valueOf();
Integer jjj = 1;
编译后源码:
Integer jjj = Integer.valueOf(1);
拆箱: 自动对象.intValue();
int jjj = new Integer(2);
编译后源码:
int jjj = (new Integer(2)).intValue();
EG:
示例代码:
public class Test { public static void main(final String[] args) { Integer a = 100; Integer b = 100; System.out.println(a == b); main2(); main3(); } public static void main2() { Integer a = 156; Integer b = 156; System.out.println(a == b); } public static void main3() { int a = new Integer(156); int b = Integer.valueOf(156); System.out.println(a == b); } }
经过装箱拆箱本质代码为:
public class Test { public static void main(String[] args) { Integer a = Integer.valueOf(100); Integer b = Integer.valueOf(100); System.out.println(a == b); main2(); main3(); } public static void main2() { Integer a = Integer.valueOf(156); Integer b = Integer.valueOf(156); System.out.println(a == b); } public static void main3() { int a = new Integer(156).intValue(); int b = Integer.valueOf(156).intValue(); System.out.println(a == b); } }
运行结果:
true false true
3. yekui说, 查了一下源码,确实如此!
java使用该机制是为了达到最小化数据输入和输出的目的,这是一种优化措施,提高效率.
valueOf缓存范围
其他的包装器:
Boolean: (全部缓存)
Byte: (全部缓存)
Character [0, 127] 缓存
Short [-128, 127] 缓存
Long [-128, 127] 缓存
Float (没有缓存)
Doulbe (没有缓存)