【Java】从源码角度分析128陷阱

一、从概念了解128陷阱

在 Java 中,整型包装类 java.lang.Integer 存在一个 “128 陷阱”,具体指的是在范围为 -128 到 127 之间的整数值(包括 -128 和 127),在自动装箱(Autoboxing)时会被缓存,而超出这个范围的整数值则不会被缓存。这是由于 Integer 类在内部使用了一个缓存池(Cache),目的是为了提高性能和节省内存。( Java拆箱装箱
当使用自动装箱或 Integer.valueOf() 方法将一个整数赋值给 Integer 类型的变量时,如果这个整数值在 -128 到 127 之间,将直接从缓存池中获取 Integer 对象,而不会创建新的对象。这样做的好处是可以重用已有的对象,减少了对象的创建和销毁开销。然而这种缓存机制可能导致128陷阱。
由于-128到127的整数数值是被缓存的,当你比较两个处于这个范围内的‘ Integer ’对象时,使用‘==’运算符时会返回true,因为他们引用的同一个缓存对象
代码示例:

Integer a = 127;
Integer b = 127;
System.out.println(a == b); // 输出 true

Integer c = 128;
Integer d = 128;
System.out.println
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

去码头整点薯条​⁢⁢⁢⁡

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

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

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

打赏作者

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

抵扣说明:

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

余额充值