理解 Java 中整数装箱的奇怪之处
在 Java 中,像整数这样的原始数据类型都有相应的包装类,例如 Integer,提供面向对象的功能。这些值的装箱和拆箱方式可能会导致令人惊讶的结果。
这样的观察来自以下代码:
public class WeirdBoxing { public static void main(String[] args) { Integer a = 1000, b = 1000; System.out.println(a == b); Integer c = 100, d = 100; System.out.println(c == d); } }
执行时,此代码将打印:
false true
为什么第一次比较返回 false,而第二次比较返回 true?根据 == 运算符,引用应该始终进行比较。
“真实”比较背后的奥秘
有趣的是,真正的比较并不是侥幸。 Java 语言规范 (JLS) 第 5.1.7 节规定:
如果装箱的值 p 是 [...] -128 到 127 之间的 int 或短数字,[...] 那么让 r1 和r2 是 p 的任意两次装箱转换的结果。总是存在 r1 == r2 的情况。
在这种情况下,c 和 d 都将值保留在指定范围内,导致它们的装箱表示(整数对象)相同。
非固定范围比较的歧义
相反,第一个比较(a == b) 不属于保证相等规则。 JLS 强调这一点:
对于其他值,[规则]不允许程序员对装箱值的身份进行任何假设。
本质上,当装箱值超出固定范围时,不保证相同
结论
Java 中整数装箱的奇怪行为源于语言规范对效率和常见用例的规定。虽然一定范围内的值保证被相同地装箱,但对于其他值,装箱对象的身份是不可预测的。这种理解阐明了开头提供的代码片段所例证的“怪异”。
以上是为什么 Java 中的整数装箱对于'==”比较有时返回'true”,有时返回'false”?的详细内容。更多信息请关注PHP中文网其他相关文章!