我想考“==”操作上Long
S和这是我发现:下面的代码:这种奇怪的Java行为的原因是什么?
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将[-128, 127]
中的所有long
值存储在Perm空间中,并将它们的地址提供给Long
s,并且将上述范围外的所有内容都存储在代码中为每个静态值创建的新分配。
我接近了吗?在什么情况下我们必须意识到类似的行为?
PS。我知道我应该使用null
检查,然后.equals()
来比较对象,但我很好奇,如果有人知道答案。
编辑
后jtahlborn的回答谁给我的关键字自动装箱我发现与well-documented answer
是的,你是对的。 (是的,在这里使用'=='而不是'.equals'是一种罪行。) – 2012-08-14 18:00:50
http://stackoverflow.com/questions/11955958/with-abstract-datatypes-different-results-for-the-same-条件/ 11955984#11955984 – kosa 2012-08-14 18:06:22
您不应该使用空检查。零检查是邪恶的。只是不要使用NULL。 – 2013-11-10 07:57:29