在Java中,處理含有泛型的Equals方法時,需要確保類型安全并避免運行時類型錯誤
首先,讓我們創建一個簡單的泛型類MyClass<T>
:
public class MyClass<T> {
private T value;
public MyClass(T value) {
this.value = value;
}
public T getValue() {
return value;
}
public void setValue(T value) {
this.value = value;
}
}
現在我們需要為這個類實現一個正確的equals方法。為此,我們可以使用Java的Objects.equals()
方法來比較泛型類型的值:
import java.util.Objects;
public class MyClass<T> {
// ... 其他代碼 ...
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
MyClass<?> myClass = (MyClass<?>) o;
return Objects.equals(value, myClass.value);
}
@Override
public int hashCode() {
return Objects.hash(value);
}
}
這里的關鍵是使用MyClass<?>
而不是MyClass<T>
來執行向下轉型。這樣,我們可以在equals()
方法中安全地比較泛型類型的值,而不用擔心具體的類型參數。
注意,當重寫equals方法時,也應該重寫hashCode方法,以確保兩個相等的對象具有相同的哈希碼。這有助于提高哈希表(如HashMap和HashSet)的性能。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。