为什么Integer类型用==比较时127相等128不相等?【Integer 类型在范围[-128,127] 使用== 的比较问题】

本文探讨了Java中Integer类型在-128至127范围内使用==进行比较的特殊行为,解释了为何127比较时为true,而128为false的现象。深入分析了自动装箱过程中IntegerCache.cache的作用,以及它如何影响对象的比较。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Integer 类型在范围[-128,127] 使用==的比较问题

直接上代码:

	public static void main(String[] args) {
        Integer a  = new Integer(1);
        Integer b  = new Integer(1);
        System.out.println(a==b);
        System.out.println(a.equals(b));
        a=1;
        b=1;
        System.out.println(a==b);
        a=127;
        b=127;
        System.out.println(a==b);
        a=128;
        b=128;
        System.out.println(a==b);
    }

运行结果:
在这里插入图片描述
疑问:为什么127比较时为true,128为false???

结果分析:

  • 对于基本类型,= = 判断两个值是否相等,基本类型没有 equals() 方法。
  • 对于引用类型,= = 判断两个变量是否引用同一个对象,而 equals() 判断引用的对象是否等价。

第一个结果是false,显而易见是new了两个对象。
第二个结果是true,因为equals比较的是两个对象的真实值,也就是堆中的1。
第三个结果是true,直接给ab赋值。
第四个结果是true,直接给ab赋值。
第五个结果是false,直接给ab赋值。

这时候问题来了,为什么同样是赋值,结果却不一样?

a=127;自动装箱,相当于调用了Integer.valueOf(127);方法。
    自动装箱时首先判断i值是否在-128和127之间,如果在-128和127之间则直接从IntegerCache.cache缓存中获取指定数字的包装类;不存在则new出一个新的包装类。
    IntegerCache内部实现了一个Integer的静态常量数组,在类加载的时候,执行static静态块进行初始化-128到127之间的Integer对象,存放到cache数组中。cache属于常量,存放在java的方法区中。这样调用时会使用缓存池中的对象,多次调用会取得同一个对象的引用。

我们查看一下Integer类的源码中有这样一个方法:

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

关于装箱插箱和缓存池的更多知识:https://blog.youkuaiyun.com/Brad_PiTt7/article/details/98774996

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员小台

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值