微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

这种奇怪的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().

原文地址:https://www.jb51.cc/java/121647.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐