在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。
推薦閱讀:
- Java Long類型對比分析
- java兩個integer數據判斷相等用==還是equals
- Java中如何正確重寫equals方法
- Java Object類和包裝類深入解讀
- 詳談java中int和Integer的區別及自動裝箱和自動拆箱