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

前端之家收集整理的这篇文章主要介绍了这种奇怪的Java行为的原因是什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想在Longs上测试’==’运算符,这就是我发现的:以下代码
public static void main(final String[] args) {
    final Long n = 0L;
    final Long m = 0L;
    System.out.println(n + " == " + m + " : " + (n == m));

    final Long a = 127L;
    final Long b = 127L;
    System.out.println(a + " == " + b + " : " + (a == b));

    final Long A = 128L;
    final Long B = 128L;
    System.out.println(A + " == " + B + " : " + (A == B));

    final Long x = -128L;
    final Long y = -128L;
    System.out.println(x + " == " + y + " : " + (x == y));

    final Long X = -129L;
    final Long Y = -129L;
    System.out.println(X + " == " + Y + " : " + (X == Y));
}

输出

0 == 0 : true
127 == 127 : true
128 == 128 : false
-128 == -128 : true
-129 == -129 : false

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

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

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

编辑

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

解决方法

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

猜你在找的Java相关文章