2 回答

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

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