Long、long类型的比较遇到的问题:
1、long 是基本类型 Long是对象类型。
public static void main(String[] args) {
Long A = 127l;
Long B = 127l;
long C = 127;
long D = 127;
//Java中如果使用 == 双等于比较对象,等于比较的是两个对象的内存地址,也就是比较两个对象是否是同一个对象
if (C == D) {
System.out.println("C = " + C + ",D=" + D + " C == D 是" + (C == D));
}else {
System.out.println("C = " + C + ",D=" + D + " C == D 是" + (C == D));
}
//如果比较两个Long对象值是否相等,则不可以使用双等号进行比较, 要使 equals 方法 或者 a.longValue()==b.longValue()
//值在[-128, 127]之间,会放在缓存里面,而超过这个范围就要new一个新的对象,也就是说==不能判断对象是否相等。
if (A == B) {
System.out.println("A = " + A + ",B=" + B + " A == B 是" + (A == B));
}else {
System.out.println("A = " + A + ",B=" + B + " A == B 是" + (A == B));
}
if (A.longValue() == B.longValue()) {
System.out.println("A = " + A + ",B=" + B + " A longValue B 是" + (A.longValue() == B.longValue()));
}else{
System.out.println("A = " + A + ",B=" + B + " A longValue B 是" + (A.longValue() == B.longValue()));
}
if (A.equals(B)) {
System.out.println("A = " + A + ",B=" + B + " A equals B 是" + (A.equals(B)));
}else{
System.out.println("A = " + A + ",B=" + B + " A equals B 是" + (A.equals(B)));
}
if (A.compareTo(B) == 0) {
System.out.println("A = " + A + ",B=" + B + " A compareTo B 是" + (A.compareTo(B) == 0));
}else{
System.out.println("A = " + A + ",B=" + B + " A compareTo B 是" + (A.compareTo(B) == 0));
}
}
结果输出:
C = 128,D=128 C == D 是true
A = 128,B=128 A == B 是false
A = 128,B=128 A longValue B 是true
A = 128,B=128 A equals B 是true
A = 128,B=128 A compareTo B 是true
C = 127,D=127 C == D 是true
A = 127,B=127 A == B 是true
A = 127,B=127 A longValue B 是true
A = 127,B=127 A equals B 是true
A = 127,B=127 A compareTo B 是true
2、我们注意到:两个Long对象值是否相等,超过127用==就不相等了。下面是Long源码
public static Long valueOf(long l) {
final int offset = 128;
if (l >= -128 && l <= 127) { // will cache
return LongCache.cache[(int)l + offset];
}
return new Long(l);
}
Java中如果使用 == 双等于比较对象,等于比较的是两个对象的内存地址,也就是比较两个对象是否是同一个对象。
如果比较两个Long对象值是否相等,则不可以使用双等号进行比较, 要使 equals 方法 或者 a.longValue()==b.longValue(),值在[-128, 127]之间,会放在缓存里面,而超过这个范围就要new一个新的对象,也就是说==不能判断对象是否相等。
每天努力一点,每天都在进步。