在判断两个Long型数据是否相等的时候遇到了一个问题。
if(sku.getId()==admin.getId()){returntrue;}else{returnfalse;}两个Long型的ID之间的比较,结果却是false。Longid1=123L;Longid2=123L;System.out.println(id1==id2);输出:true
源代码:
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的实例。
因此用==比较时 如果参数在-128至127 取的是同一个缓存池里的对象 比较地址 相同 返回true ,一旦超过这个范围 false
使用equals
Long重写了equals方法,如下:
public boolean equals(Object obj) { if (obj instanceof Long) { return value == ((Long)obj).longValue(); } return false; }
它是先通过.longValue()方法获取Long对象的基本类型long的值之后再做比较的。
所以,最好还是使用equals进行比较。