基于Java8
在Java中,Integer是基本类型int的封装类。在Java1.5之前,都是需要手动装箱和拆箱的,而1.5之后则系统自动完成(网上是这么说的,我也不知道真假,毕竟1.5盛行的时候我还是个孩子)。那么是什么支撑着这(些)个包装类型度过1.5之前的那些日子呢?是Java祖传的强大生命力吗(毕竟一直被唱衰,但目前还是不会死)?主要就是Java面向对象的特征了,包装之后可以调用里面的方法,并且把MAX_VALUE等常量封装进去了。还有一个重点就是多了个null,不要谈什么无限大+1=无限大。
那么他们两个是怎么进行转换的呢?主要是靠的下面两个方法(都是源码):
//很明显,这是把int转换为Integer
public static Integer valueOf(int i) {
if (i >= IntegerCache.low && i <= IntegerCache.high)
return IntegerCache.cache[i + (-IntegerCache.low)];
return new Integer(i);
}
//很明显,这是把Integer转换为int
public int intValue() {
return value;
}
在上面的valueOf方法中我们可以看到有个IntegerCache,从字面意义上理解就是缓存的意思。在Integer中有一个内部类IntegerCache,它用静态代码块完成了缓存的初始化工作。缓存区的大小为-128~127,还有些源码没看懂,先(没)不(法)贴(装)了。
那么缓存来了,同一个对象就实现了,请尝试运行下面代码:
public class test {
public static void main(String[] args) {
Integer a=new Integer(12);
Integer b=new Integer(12);
System.out.println(a==b);
}
}
你会发现结果是false,因为直接new的话走的是下面的方法:
public Integer(int value) {
this.value = value;
}
也就是说,上面new的两个对象除了数值相等真的就没有什么了。这个时候equals方法返回的是true。
public boolean equals(Object obj) {
if (obj instanceof Integer) {
return value == ((Integer)obj).intValue();
}
return false;
}
那么我们如果想从缓存池中取,应该调用的是下面的方法:
方法就在上面呢,直接赋值就行,也就是valueOf。