當我們從超類重寫 equals() 方法時,需要 hashcode() 方法的新實現。equals() 和 hashcode() 之間的約定得到保留。
2 回答

蝴蝶刀刀
TA貢獻1801條經驗 獲得超8個贊
和equals
方法hashCode
(就像任何其他方法一樣)將從超類繼承。
如果這些仍然適合子類,您可以保持原樣。
JDK中有這樣的例子:
Stack
延伸Vector
延伸AbstractList
Stack
只是繼承equals
自Vector
Vector
覆蓋equals
fromAbstractList
,但僅添加synchronized
然后調用super.equals
。ArrayList
也擴展了AbstractList
,但它覆蓋了equals
遵循相同邏輯的實現,但可以更有效,因為它知道至少有一個參與者是ArrayList
.
但請記住
您現在將使用相同的代碼比較所有組合中的 Super <-> Super、Super <-> Sub、Sub <-> Sub 實例
當實際上可以是子類時,類似的事情
this.getClass()
可能會返回意想不到的事情this
如果這會導致您的比較邏輯出現問題,則由您決定。

蠱毒傳說
TA貢獻1895條經驗 獲得超3個贊
當您要在基于散列的集合中使用該類時,需要保留 equals 和 hashcode 方法之間的契約,例如 hashmap、hashset 等,它們使用 hashcode 方法來計算散列索引,并使用 equals 方法來檢查相等性。否則你可以忽略哈希碼。
添加回答
舉報
0/150
提交
取消