这种奇怪的Java行为的原因是什么?

前端之家收集整理的这篇文章主要介绍了这种奇怪的Java行为的原因是什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想在Longs上测试’==’运算符,这就是我发现的:以下代码
  1. public static void main(final String[] args) {
  2. final Long n = 0L;
  3. final Long m = 0L;
  4. System.out.println(n + " == " + m + " : " + (n == m));
  5.  
  6. final Long a = 127L;
  7. final Long b = 127L;
  8. System.out.println(a + " == " + b + " : " + (a == b));
  9.  
  10. final Long A = 128L;
  11. final Long B = 128L;
  12. System.out.println(A + " == " + B + " : " + (A == B));
  13.  
  14. final Long x = -128L;
  15. final Long y = -128L;
  16. System.out.println(x + " == " + y + " : " + (x == y));
  17.  
  18. final Long X = -129L;
  19. final Long Y = -129L;
  20. System.out.println(X + " == " + Y + " : " + (X == Y));
  21. }

输出

  1. 0 == 0 : true
  2. 127 == 127 : true
  3. 128 == 128 : false
  4. -128 == -128 : true
  5. -129 == -129 : false

我能想到的唯一解释是JVM将所有长值存储在Perm空间中的[-128,127]内,并将它们的地址提供给Longs以及上述范围之外的所有值,它为每个静态值创建一个新的分配在代码中遇到了.

我接近正确吗?我们在什么情况下必须注意类似的行为?

PS.我知道我应该使用nullcheck然后使用.equals()来比较对象,但我很好奇是否有人知道答案.

编辑

在jtahlborn回答谁给我关键字自动拳击后,我发现了这篇关于well-documented answer的精彩文章

解决方法

这是自动装箱的结果.见 Long.valueOf().

猜你在找的Java相关文章