2 回答

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

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