在判斷兩個Long型數據是否相等的時候遇到了一個問題。 <! more 使用“==”的疑問 兩個Long型的ID之間的比較,結果卻是false。 再看一個 同是Long型,同是 ,為什麼結果不一樣呢? 看看源代碼: java private static class LongCache { priv
在判斷兩個Long型數據是否相等的時候遇到了一個問題。
使用“==”的疑問
if (user.getId() == admin.getId()) {
return true;
} else {
return false;
}
兩個Long型的ID之間的比較,結果卻是false。
再看一個
Long id1 = 123L;
Long id2 = 123L;
System.out.println(id1 == id2);
輸出: 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的值之後再做比較的。
所以,最好還是使用equals
進行比較。
參考:
stackoverflow Long型比較的問題
java java.lang.Long詳解之二 緩存
JAVA中Long與Integer比較容易犯的錯誤