Java Integer之间的比较

有如下代码:

@Test
public void test1(){
    Integer i = 100;
    Integer i2 = 100;
    System.out.println(i==i2); // 输出 true
  
}

按照我们平常了解==是用来比较地址的,因为Integer是包装类,每声明一个Integer i = xxx都会创建一个对象,创建的i,i2是两个对象,用==比较,应该是false但是输出结果是true

@Test
public void test1(){
    Integer i = 100;
    Integer i2 = 100;

    Integer i3 = 300;
    Integer i4 = 300;

    System.out.println(i==i2); // 输出 true
    System.out.println(i3==i4);// 输出 false
}

再添加几行代码,此时i3与i4比较的结果却是false

对上面的代码的进行反编译,代码如下:

Integer i = Integer.valueOf(100);
Integer i2 = Integer.valueOf(100);
Integer i3 = Integer.valueOf(300);
Integer i4 = Integer.valueOf(300);
System.out.println(i == i2);
System.out.println(i3 == i4);

Integer i = xxx,自动装箱也就是调用Integer.valueOf()

// low :-128  high:127
public static Integer valueOf(int i) {
    if (i >= IntegerCache.low && i <= IntegerCache.high)
        return IntegerCache.cache[i + (-IntegerCache.low)];
    return new Integer(i);
}

在Java 5中,在Integer的操作上引入了一个新功能来节省内存和提高性能。整型对象通过使用相同的对象引用实现了缓存和重用。也就是说如果创建的Integer对象value的值范围在-128到127之间时,会存放IntegerCache当中,下次再创建的时候,会先从IntegerCache中寻找。

现在就很好理解为什么i==i1为false,因为我们创建的100在[-128,127],当创建的i对象,会存放在缓存当中,下次创建i2对象,先从缓存中寻找,因为存在,所以返回i的引用给i2。所以i与i2的地址相同。
但是当我们创建Integer i3 = 300,Integer i4 = 300;时,不满足缓存条件,那么就会调用new Integer(i),创建两个对象,那么他们的地址,自然也不相同。

总结
当我们比较包装类的时候,如果范围在【-128,127】之间,可以直接用==比较,超出这个范围要用equals,进行比较。

posted @ 2021-09-09 14:37  Quark_L  阅读(303)  评论(0)    收藏  举报