Java判断Long类型相等问题
程序员文章站
2022-04-10 14:05:23
...
// Long类型判断相等时,比如Long a = 10L, Long b = 10L;习惯是判断a == b;
Long a = 10L;
Long b = 10L;
if(a == b) { // true
System.out.println("aike1");
}
Long c = 128L;
Long d = 128L;
if(c == d) { // false
System.out.println("aike2");
}
if(c.valueOf(12) == d.valueOf(12)) { // true
System.out.println("aike3");
}
if(c.valueOf(128) == d.valueOf(128)) { // false
System.out.println("aike4");
}
// 为什么等于128时就不相等呢?
// 查看Java源码Long.class
private static class LongCache {
private LongCache(){}
static final Long cache[] = new Long[-(-128) + 127 + 1];
static {
for(int i = 0; i < cache.length; i++)
cache[i] = new Long(i - 128);
}
}
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);
}
/*原来是因为Long中有一个静态的内部类LongCache,专门用于缓存-128至127之间的值,一共256个元素。
如果仅仅是缓存下来而不去使用那么就没有任何意义。
valueOf(long l)就是使缓存派上用场的方法,它会判断传入的参数是否在-128-127之间,如果是则直接从缓存中返回对应的引用,否则新创建一个Long的实例。
对于新创建的Long实例, ==比较是否为同一对象, 所以大于127就不相等了。*/
// 判断方法 使用equals Long重写了equals方法,如下:
public boolean equals(Object obj) {
if (obj instanceof Long) {
return value == ((Long)obj).longValue();
}
return false;
}
它是先通过.longValue()方法获取Long对象的基本类型long的值之后再做比较的。
但是我们用longValue比较时容易忘记后面一个包装类调longValue方法
所以,最好还是使用equals进行比较。也可以直接用.longValue()比较
上一篇: NFS挂载遇到的问题
下一篇: 判定2个对象相等之重写equals方法