在Java中判斷兩個Long對象是否相等

拋出問題:

Long a = 4l;
Long b = 4l;
a == b //true
Long a = 128l;
Long b = 128l;
a == b //false

如果Long的值在[-127,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);
    }

如果不在[-127,128]之間,則會new一個新對象,自然“==”兩個不同的對象,其結果必然是false瞭。

解決方案:

1、使用Long中的longValue()進行轉換

Long a = 128l;
Long b = 128l;
a.longValue() == b.longValue() //true

2、使用Long中的equals()

Long a = 128l;
Long b = 128l;
a.equals(b);//true

下面是該方法源碼:

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

兩個Long類型比較存在的坑

一般來說,兩個基本數據類型比較用 “==” 就可以瞭,平時很少用Long類型比較。

但是最近寫項目時遇到瞭兩個Long類型比較,當時也是直接用的雙等於,然而當debug時卻發現代碼執行到這兩個Long類型比較判斷時並沒有進入這個判斷體內,然後上網搜索相關的問題, 其實很簡單,但是不知道的話就很很容易入坑。

解決方法具體如下:

可以讓兩個Long類型的變量分別調用 ==longValue()== 方法來實現就可以瞭。

代碼:

Long a=...;
Long b=...;
if (a.longValue() == b.longValue()) {
             ...;
}

其實Long是java數據包裝類的一種,以上屬於包裝類Long轉化為基本數據類型long的情況,以下列舉其它數據包裝類拆箱轉化為基本數據類型的情況:

Integer轉為int,需要調用intValue()方法

Double轉為double,需要調用doubleValue()方法

Float轉為float,需要調用floatValue()方法

總結:

某包裝類Xxx轉為對應的基本數據類型時,則調用xxxValue()方法。

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: