溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Object類(lèi)中Hashcode和equals區(qū)別是什么

發(fā)布時(shí)間:2021-12-22 09:07:04 來(lái)源:億速云 閱讀:114 作者:iii 欄目:編程語(yǔ)言

本篇內(nèi)容介紹了“Object類(lèi)中Hashcode和equals區(qū)別是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

  equals Object 類(lèi)中默認(rèn)的實(shí)現(xiàn)方式是 : return this == obj 。那就是說(shuō),只有 this 和 obj 引用同一個(gè)對(duì)象,才會(huì)返回 true。Hashcode這個(gè)方法返回對(duì)象的散列碼,返回值是 int 類(lèi)型的散列碼。

  equals:


  Object 類(lèi)中默認(rèn)的實(shí)現(xiàn)方式是 : return this == obj 。那就是說(shuō),只有 this 和 obj 引用同一個(gè)對(duì)象,才會(huì)返回 true。


  而我們往往需要用 equals 來(lái)判斷 2 個(gè)對(duì)象是否等價(jià),而非驗(yàn)證他們的唯一性。這樣我們?cè)趯?shí)現(xiàn)自己的類(lèi)時(shí),就要重寫(xiě)equals


  按照約定,equals 要滿足以下規(guī)則。


  自反性: x.equals(x) 一定是 true


  對(duì) null: x.equals(null) 一定是 false


  對(duì)稱(chēng)性: x.equals(y) 和 y.equals(x)結(jié)果一致


  傳遞性: a 和 b equals , b 和 c equals,那么 a 和 c也一定 equals。


  一致性: 在某個(gè)運(yùn)行時(shí)期間,2 個(gè)對(duì)象的狀態(tài)的改變不會(huì)影響 equals 的決策結(jié)果,那么,在這個(gè)運(yùn)行時(shí)期間,無(wú)論調(diào)用多少次 equals,都返回相同的結(jié)果。


  Hashcode:

     這個(gè)方法返回對(duì)象的散列碼,返回值是 int 類(lèi)型的散列碼。


  對(duì)象的散列碼是為了更好的支持基于哈希機(jī)制的 Java 集合類(lèi),


  例如 Hashtable, HashMap, HashSet 等。


  關(guān)于 hashCode 方法,一致的約定是:


  重寫(xiě)了 euqls 方法的對(duì)象必須同時(shí)重寫(xiě) hashCode()方法。


  如果 2 個(gè)對(duì)象通過(guò) equals 調(diào)用后返回是 true,那么這個(gè) 2 對(duì)象的 hashCode 方法也必須返回同樣的 int 型散列碼


  如果 2 個(gè)對(duì)象通過(guò) equals 返回 false,他們的 hashCode 返回的值允許相同。(然而,程序員必須意識(shí)到,hashCode 返回一無(wú)二的散列碼,會(huì)讓存儲(chǔ)這個(gè)對(duì)象的 hashtables 更好地作。)


  在上面的例子中,Test 類(lèi)對(duì)象有 2 個(gè)字段,num 和 data,這 2個(gè)字段代表了對(duì)象的狀態(tài),他們也用在 equals 方法中作為評(píng)判的依據(jù)。那么, 在 hashCode 方法中,這 2 個(gè)字段也要參與hash 值的運(yùn)算,作為 hash 運(yùn)算的中間參數(shù)。這點(diǎn)很關(guān)鍵,這是為了遵守:2 個(gè)對(duì)象 equals,那么 hashCode 一定相同規(guī)則。


  也是說(shuō),參與 equals 函數(shù)的字段,也必須都參與 hashCode 的計(jì)算。


  合乎情理的是:同一個(gè)類(lèi)中的不同對(duì)象返回不同的散列碼。典型的方式就是根據(jù)對(duì)象的地址來(lái)轉(zhuǎn)換為此對(duì)象的散列碼,但是這種方式對(duì)于 Java 來(lái)說(shuō)并不是唯一的要求的的實(shí)現(xiàn)方式。通常也不是最好的實(shí)現(xiàn)方式。


  相比 于 equals 公認(rèn)實(shí)現(xiàn)約定,hashCode 的公約要求是很容易理解的。有 2 個(gè)重點(diǎn)是 hashCode 方法必須遵守的。約定的第 3點(diǎn),其實(shí)就是第 2 點(diǎn)的細(xì)化,下面我們就來(lái)看看對(duì) hashCode 方法的一致約定要求。


  第一:在某個(gè)運(yùn)行時(shí)期間,只要對(duì)象的(字段的)變化不會(huì)影響 equals 方法的決策結(jié)果,那么,在這個(gè)期間,無(wú)論調(diào)用多少次 hashCode,都必須返回同一個(gè)散列碼。


  第二:通過(guò) equals 調(diào)用返回 true 的 2 個(gè)對(duì)象的 hashCode 一定一樣。


  第三:通過(guò) equasl 返回 false 的 2 個(gè)對(duì)象的散列碼不需要不同,也就是他們的 hashCode 方法的返回值允許出現(xiàn)相同的情況。


  總結(jié)一句話:等價(jià)的(調(diào)用 equals 返回 true)對(duì)象必須產(chǎn)生相同的散列碼。不等價(jià)的對(duì)象,不要求產(chǎn)生的散列碼不相同。

“Object類(lèi)中Hashcode和equals區(qū)別是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI