本篇內(nèi)容介紹了“Object類(lèi)中Hashcode和equals區(qū)別是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
成都創(chuàng)新互聯(lián)公司是專(zhuān)業(yè)的昌寧網(wǎng)站建設(shè)公司,昌寧接單;提供做網(wǎng)站、網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專(zhuān)業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行昌寧網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專(zhuān)業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專(zhuān)業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!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 要滿(mǎn)足以下規(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é)一句話(huà):等價(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)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線(xiàn),公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿(mǎn)足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。
網(wǎng)站欄目:Object類(lèi)中Hashcode和equals區(qū)別是什么-創(chuàng)新互聯(lián)
文章出自:http://m.newbst.com/article6/hpiig.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁(yè)設(shè)計(jì)公司、品牌網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計(jì)、手機(jī)網(wǎng)站建設(shè)、網(wǎng)站維護(hù)、App設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容