一、HashCode(哈希碼)
hashCode
是一個(gè)用于確定對(duì)象在哈希表中存儲(chǔ)位置的整型數(shù)值。
它是由Java虛擬機(jī)根據(jù)對(duì)象的內(nèi)存地址或內(nèi)容計(jì)算得到的,并且在對(duì)象的生命周期中保持不變。
在使用Java集合框架中的哈希表數(shù)據(jù)結(jié)構(gòu)(如HashMap、HashSet等)時(shí),hashCode
方法用于確定對(duì)象在哈希表中的索引位置,從而快速訪問(wèn)和存儲(chǔ)對(duì)象。
二、Equals(相等性判斷)
equals
方法是用于比較兩個(gè)對(duì)象是否相等。
在Java中,默認(rèn)情況下,equals
方法與==
運(yùn)算符作用相同,即比較兩個(gè)對(duì)象的引用是否指向同一內(nèi)存地址。
但是,在許多情況下,我們需要自定義equals
方法,使其根據(jù)對(duì)象的內(nèi)容(屬性值)來(lái)判斷相等性。這需要重寫equals
方法,以便根據(jù)業(yè)務(wù)需求比較對(duì)象的屬性值是否相等。
三、區(qū)別與使用場(chǎng)景
HashCode和Equals的關(guān)系: 在Java中,hashCode
和equals
有著緊密的關(guān)聯(lián)。在自定義equals
方法時(shí),通常也需要重寫hashCode
方法,以保證當(dāng)兩個(gè)對(duì)象相等時(shí),它們的哈希碼也相等。這是為了保證在使用哈希表的數(shù)據(jù)結(jié)構(gòu)時(shí)能夠正確地查找和比較對(duì)象。HashCode和Equals的使用場(chǎng)景:hashCode
主要用于在哈希表中查找對(duì)象,所以在使用HashMap、HashSet等集合類時(shí),要保證重寫的equals
方法和hashCode
方法的邏輯一致性,即相等的對(duì)象必須具有相等的哈希碼。equals
方法主要用于判斷對(duì)象的內(nèi)容是否相等,例如在自定義的類中,如果兩個(gè)對(duì)象的屬性值相等,則可以視為它們相等,這時(shí)就需要重寫equals
方法。延伸閱讀
解決哈希沖突:鏈表法和紅黑樹法
鏈表法: 當(dāng)哈希表中的某個(gè)索引位置有多個(gè)對(duì)象的哈希碼相同,這些對(duì)象將以鏈表的形式存儲(chǔ)在該位置。在查找對(duì)象時(shí),先根據(jù)哈希碼找到索引位置,再遍歷鏈表進(jìn)行對(duì)象比較。鏈表法適用于哈希沖突較少的情況,但當(dāng)鏈表過(guò)長(zhǎng)時(shí),會(huì)影響查找效率。紅黑樹法: 為了優(yōu)化鏈表法中長(zhǎng)鏈表的查找效率,Java在JDK 8中引入了紅黑樹法。當(dāng)鏈表長(zhǎng)度超過(guò)一定閾值時(shí),鏈表將轉(zhuǎn)換為紅黑樹,從而提高查找性能。紅黑樹是一種自平衡的二叉搜索樹,具有快速的查找、插入和刪除操作。通過(guò)鏈表法和紅黑樹法,Java集合框架能夠高效處理哈希沖突,保證了集合類的性能和穩(wěn)定性。在使用自定義的類作為HashMap的鍵時(shí),要注意確保正確實(shí)現(xiàn)equals
和hashCode
方法,以避免潛在的哈希沖突問(wèn)題。