當我們從超類重寫 equals() 方法時,需要 hashcode() 方法的新實現。equals() 和 hashcode() 之間的約定得到保留。
2 回答
蝴蝶刀刀
TA貢獻1801條經驗 獲得超8個贊
和equals方法hashCode(就像任何其他方法一樣)將從超類繼承。
如果這些仍然適合子類,您可以保持原樣。
JDK中有這樣的例子:
Stack延伸Vector延伸AbstractListStack只是繼承equals自VectorVector覆蓋equalsfromAbstractList,但僅添加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
提交
取消
