1 2 3 4

Long类型的数据判断是否相等

Long是一个类,判断是否相等时如果数据小于128L时,用equals和== 都是可以的,但超过128L再用==判断是否相等就会出问题,所以Long类型的数据判断是否相等可以使用equals(最好)进行比较,也可以直接用.longValue()比较,其他包装类型Integer,Byte,Float,Double等雷同

//itemId orderItem.getItemId()均为Long类型
if
(itemId.longValue()==orderItem.getItemId().longValue()) { return orderItem; } //或者 if (itemId.equals(orderItem.getItemId())) { return orderItem; }

 

 

在判断两个Long型数据是否相等的时候遇到了一个问题:

if (user.getId() == admin.getId()) {  
    return true; 
} else {
    return false;
}

代码执行结果如下:

Long i = 12L;
Long j = 12L;
Long m = 195L;
Long n = 195L;
System.out.println(i=j);//true
System.out.println(m=n);//false
System.out.println(i.equals(j));//true
System.out.println(m.equals(n));//true

同是Long型,同是==,为什么结果不一样呢?

看看源代码:

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的实例。

 

使用equals

Long重写了equals方法,如下:

public boolean equals(Object obj) {  
  if (obj instanceof Long) {
      return value == ((Long)obj).longValue();
  }
  return false;
  }

它是先通过.longValue()方法获取Long对象的基本类型long的值之后再做比较的。

 

posted @ 2019-07-23 17:43  Mr_Elliot  阅读(4683)  评论(0编辑  收藏  举报
PV