一、Integer与int基本介绍
(1)Integer是int的包装类;int是基本数据类型
(2)Integer变量必须实例化后才可以使用,而int变量则不需要
(3)Integer本质上是对对象的引用,当new一个Integer时,实际是生成一个指针指向此对象;
而int则是直接存储数据
(4)Integer的默认值是null,而int的默认值为0
二、Integer与int详细比较
(1)Integer变量和int变量比较时,只要这两个变量的值是相等的,那么输出的结果就为true;
这是因为java会将integer变量自动拆包装为int变量,实际上也就变成了两个int类型变量的 比较,由于两个int变量的值相等,那么自然就输出为true了。代码示例如下:
Integer i = new Integer(100);
int j = 100;
System.out.println(i == j); //true
(2)两个new出来的Integer变量进行比较时,永远都是false。因为integer变量实际上是对一个Integer对象的引用,所以两个new出来的Integer变量的内存地址一定是不相同的,即为false
代码示例如下:
Integer a = new Integer(100);
Integer b = new Integer(100);
System.out.println(a == b);//false
(3)一个new出来的Integer变量和一个非new的Integer变量比较时,也为false
Integer x = new Integer(100);
Integer y = 100;
System.out.println(x == y);//false
//x指向的是堆中的对象,而y指向的是缓存中的对象,故为false
(4)两个非new生成的对象进行比较时,如果两个变量的值在区间-128~127之内,且两个的值相等,那么则输出为true(这是因为此时两个变量指向的是缓存中的同一对象);而如果不在这个区间内,则输出为false。代码示例如下:
Integer x = -128;
Integer y = -128;
System.out.println(x == y);//true
Integer x = 128;
Integer y = 128;
System.out.println(x == y);//false
深究(4)中具体原因如下:
对于以非new形式生成的Integer对象,即Integer i = 100,实际上在编译时会将其翻译为 Integer i = Integer.valueOf(100),而查阅javaAPI可知Integer.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变量处于-128~127这个区间时,则会指向缓存中已有的对象;反之则会指向重新new出的Integer对象。