为什么整数常量池的行为在 127 之后有所不同
Java 中数字的常量池与字符串的常量池不同。虽然只有编译时常量被保留在字符串中,但任何装箱操作都涉及整数包装类型的池。
例如:
int x = 10; int y = x + 1; Integer z = y; // Not a compile-time constant Integer constant = 11; System.out.println(z == constant); // true
JLS 保证了小范围的池值,实现可以选择使用更大的范围。
实际上,大多数实现使用 Integer.valueOf 进行装箱操作,导致以下行为:
Integer x = Integer.valueOf(100); Integer y = Integer.valueOf(100); System.out.println(x == y); // true
根据 JLS 部分5.1.7:
-128 到 127 之间的值在装箱时将始终产生相同的引用。这是一个实际的折衷方案,可确保共同值始终无法区分。
但是,超出此范围的值的行为会发生变化。出于效率原因,实现可能不会假设这些值的共享引用。
这可以确保在大多数情况下实现所需的行为,而不会显着影响性能。内存限制的实现可以扩展缓存以覆盖更广泛的值。
以上是为什么 -128 到 127 范围之外的整数值在 Java 常量池中表现不同?的详细内容。更多信息请关注PHP中文网其他相关文章!