java中Long类型和long类型比较
1.0最近在开发中比较两个long类型的值时,遇见明明两个数值都相等,但是结果却是false ,写了demo测试结果确实如此。话不多说,看代码
public class Test {
public static void main(String[] args) {
Long a=12L;
Long b = Long.valueOf(12L);
System.out.println(a==b);//ture
System.out.println(a.equals(b));//ture
}
}
1.1注意这个时候不管是==,还是equals返回值都是ture。接着看下面代码
public class Test {
public static void main(String[] args) {
Long a=1234L;
Long b = Long.valueOf(1234L);
System.out.println(a==b);//false
System.out.println(a.equals(b));//ture
}
}
1.2改变long类型的数值时,==比较数值却变成了false。这是什么原因造成的呢,查看源码发现。
* @param l a long value.
* @return a {@code Long} instance representing {@code l}.
* @since 1.5
*/
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);
}
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);
}
}
1.3原来是因为Long中有一个静态的内部类LongCache,专门用于缓存-128至127之间的值,一共256个元素。如果仅仅是缓存下来而不去使用那么就没有任何意义。valueOf(long l)就是使缓存派上用场的方法,它会判断传入的参数是否在-128-127之间,如果是则直接从缓存中返回对应的引用,否则新创建一个Long的实例。
**
2最好是使用equals方法,Long重写了equals方法,如下:
**
public boolean equals(Object obj) {
if (obj instanceof Long) {
return value == ((Long)obj).longValue();
}
return false;
}
它是先通过.longValue()方法获取Long对象的基本类型long的值之后再做比较的。