日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java延迟覆盖_高效Java第九条覆盖equals时总要覆盖hashCode

發布時間:2023/12/10 java 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java延迟覆盖_高效Java第九条覆盖equals时总要覆盖hashCode 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原標題:高效Java第九條覆蓋equals時總要覆蓋hashCode

高效Java第九條覆蓋equals時總要覆蓋hashCode

在每個覆蓋了equals方法的類中,也必須覆蓋hashCode方法。否則會導致該類無法與基于散列的集合一起正常運作。 hashCode約定

在應用程序的執行期間,只要對象的equals方法所用到的信息沒有被修改,那么對著同一個對象調用多次,hashCode方法都必須始終如一地返回同一個整數。

如果兩個對象equals(Object)方法比較是相等的,那么調用這兩個對象的hashCode方法必須產生同樣的整數結果。

如果兩個對象equals(Object)比較是不相等的,那么調用這兩個對象中的hashCode方法,則不一定要產生不同的整數結果。但是給不相等的對象產生截然不同的整數結果,有可能提高散列表的性能。 沒有覆蓋hashCode違反第二條約定

因沒有覆蓋hashCode而違反的關鍵約定是第二條:相等的對象必須具有相等的散列碼。 PhoneNumber例子——沒有覆蓋hashCode

該類無法與HashMap一起正常工作:

m.get(new PhoneNumber(408, 867, 5309))返回null。由于PhoneNumber類沒有覆蓋hashCode方法,從而導致兩個相等的實例具有不相等的散列碼,違反了hashCode的約定。因此,put方法把電話號碼對象存放在一個散列桶中,get方法卻在另一個散列桶中查找這個電話號碼。即使這兩個實例正好被放到同一個散列桶中,get方法也必定會返回null,因為HahsMsap有一項優化,可以將每個項相關聯的散列碼緩存起來,如果散列碼不匹配,也不必檢驗對象的等同性。

給PhoneNumber類提供一個適當的hashCode方法。下面的hashCode方法是錯誤的:

雖然上面的hashCode方法確保了相等的對象總是具有同樣的散列碼。但是它使得每個對象都具有同樣的散列碼。因此,每個對象都被映射到同一個散列桶中,使散列表退化為鏈表。它使得本該線性時間運行的程序變成了以平方級時間在運行。對于規模很大的散列表而言,這關系到散列表能否正常工作。 如何編寫好的散列函數

一個好的散列函數傾向于為不相等的對象產生不相等的散列碼。散列函數應該把集合中不相等的實例均勻地分布到所有可能的散列值上。

1.把某個非零的常數值,比如17,保存在一個名為result的int類型的變量中。2.對于對象中每個關鍵域f(指equals方法涉及的每個域),完成以下步驟:a。為該域計算int類型的散列碼c:i.如果該域是boolean類型,則計算(f?1:0)。ii.如果該域是byte、char、short或者int類型,則計算(int)f。iii.如果該域是long類型,則計算(int)(f ^ (f >>> 32))。iv.如果該域是float類型,則計算Float.floatToIntBits(f)。v.如果該域是double類型,則計算Double.doubleToLongBits(f),然后按照步驟2.a.iii,為得到的long類型值計算散列值。vi.如果該域是一個對象引用,并且該類的equals方法通過遞歸地調用equals方法來比較這個域,則同樣為這個域遞歸地調用hashCode。如果需要更復雜的比較,則為這個域計算一個范式,然后針對這個范式調用hashCode。如果這個域的值為null,則返回0(或者其他某個常數,但通常是0)。

vii.如果該域是一個數組,則要把每一個元素當做單獨的域來處理。遞歸地應用上述規則,對每個重要的元素計算一個散列碼,然后根據步驟2.b中的做法把這些散列值組合起來。如果數組域中的每個元素都很重要,建議使用Arrays.hashCode方法。b.把步驟2.a中計算得到的散列碼c合并到result中:result = 31 * result + c;3.返回result。

4.寫完了hashCode方法之后,問問自己“相等的實例是否都具有相等的散列碼”。建議編寫單元測試。

計算散列碼可以把冗余域排除在外。如果一個域的值可以根據參與計算的其他域的值計算出來,則可以把這樣的域排除在外。必須排除equals比較計算中沒有用到的任何域,否則很有可能違反hashCode約定的第二條。

值17是任選的。步驟2.b中的乘法部分使得散列值依賴于域的順序,如果一個類中包含多個相似的域,這樣的乘法運算就會產生一個更好的散列函數。String的散列函數省略了乘法部分,那么只是字母順序不同的所有字符串就會有相同的散列碼。選擇31是因為它是一個奇素數。如果乘數是偶數,并且乘法溢出的話,信息就會丟失,因為與2相乘等價于移位運算。使用素數的好處并不很明顯,但習慣上都使用素數來計算散列結果。31可以利用移位和減法來代替乘法,可以得到更好的性能:31 * i == (i << 5) -i。JVM可以自動完成這種優化。 給PhoneNumber編寫好的hashCode

PhoneNumber類的hashCode:

緩存散列碼

不可變類如果計算散列碼的開銷比較大,就應該考慮把散列碼緩存在對象內部,而不是每次請求的時候都重新計算散列碼。如果類的大多數對象都會被用做散列鍵,就應該在創建實例的時候計算散列碼。否則,可以選擇“延遲初始化”散列碼,一直到hashCode被第一次調用的時候才初始化。PhoneNumber類的對象有可能會經常被作為散列鍵:

不要排除對象的關鍵部分

不要試圖從散列碼計算中排除掉一個對象的關鍵部分來提高性能。即使這樣得到的散列函數運行起來更快,但是它的效果不見得會好,可能會導致散列表慢到根本無法使用。在實踐中,散列函數可能面臨大量的實例,在選擇忽略的區域之中,這些實例區別非常大。散列函數會把所有這些實例映射到極少數的散列碼上,基于散列的集合將會顯示出平方級的性能指標。JDK2之前的String散列函數至多只檢查16個字符,從第一個字符開始,在整個字符串中均勻選取。對于大型集合,該散列函數表現出了病態行為。 不要規定散列函數的細節

Java平臺類庫中的許多類,String、Integer、Date等都可以把hashCode方法返回的確切值規定為該實例值的一個函數。但是這并不是一個好注意,這會嚴格地限制了在將來的版本中改進散列函數的能力。如果沒有規定散列函數的細節,那么當你發現了它的內部缺陷時,就可以在后面的發行版本中修正它,確信沒有任何客戶端會依賴于散列函數返回的確切值。返回搜狐,查看更多

責任編輯:

總結

以上是生活随笔為你收集整理的java延迟覆盖_高效Java第九条覆盖equals时总要覆盖hashCode的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 午夜视频成人 | 在线观看污污视频 | 成年人天堂 | 日韩亚洲精品中文字幕 | 99re伊人 | 午夜福利视频一区二区 | 成人乱人乱一区二区三区一级视频 | 午夜视频观看 | 制服.丝袜.亚洲.中文.综合懂 | 成人资源站| 67194av | 久久久精品国产sm调教 | 中国一区二区视频 | 日韩欧美一区二区在线观看 | av一级在线观看 | av一区不卡 | 亚洲一本二本 | 欧美国产日韩视频 | 欧美日韩高清一区二区三区 | 婷婷亚洲精品 | 欧美播放 | 嫩草研究院在线观看 | 一区二区在线看 | 人妻换人妻仑乱 | 火影忍者羞羞漫画 | 8x国产一区二区三区精品推荐 | 五月婷婷久 | 午夜精品毛片 | 一个人在线观看免费视频www | 涩涩的视频在线观看 | 亚洲国产精品国自产拍av | 国产一二三在线观看 | 国产精品偷伦视频免费看 | 久久精品综合视频 | 在线观看国产视频 | 国产一级片黄色 | 野花社区视频在线观看 | 五月天婷婷在线播放 | 亚洲精品99久久久久中文字幕 | 四虎影视免费永久大全 | 国产伦精品一区二区三区四区免费 | 男女涩涩网站 | www.色在线观看 | 亚洲free性xxxx护士白浆 | 99国产精品99久久久久久粉嫩 | 成年人免费网站在线观看 | 999久久久国产 | 丝袜诱惑一区 | 国产精品久久久久久久久久久久久久 | 欧美成人精品一区二区 | 中文字幕欧美人妻精品一区蜜臀 | 四虎影视免费永久大全 | 国产女人18毛片水真多18精品 | 免费欧美黄色片 | 蘑菇av| 国产美女黄色片 | 国产性猛交╳xxx乱大交一区 | 欧美高清在线 | 国产精品第1页 | 69sex久久精品国产麻豆 | 国产美女免费视频 | 久久性爱视频网站 | 激情小视频在线观看 | 日本一区二区视频免费 | 国产精品久久久久久久久绿色 | 亚洲欧美少妇 | 成人在线亚洲 | 亚洲午夜精品一区二区 | 国产二区电影 | 亚洲综合在线播放 | 国产精品入口日韩视频大尺度 | 扒开美女内裤狂揉下部 | 三年电影在线观看 | 无码少妇一级AV片在线观看 | 亚洲在线观看免费 | 国产av一区二区三区传媒 | 国产91九色 | 国产精品丝袜视频 | 精品久久久久一区 | 视频一区 国产 | 久久综合亚洲色hezyo国产 | 熟妇人妻中文字幕无码老熟妇 | jizz性欧美23 | 18视频在线观看娇喘 | 校园激情亚洲 | 国产第一页在线播放 | 熟妇人妻精品一区二区三区视频 | 亚洲久久久久久 | 在线观看亚洲精品视频 | 美女扒开尿口让男人桶 | 丰满人妻一区二区三区53 | 成人中文字幕在线观看 | 无码国产精品一区二区免费16 | 欧美一区二区三区视频在线 | 久草手机在线 | 国产精品一区二区三区免费观看 | 青草一区 | 久久精品丝袜高跟鞋 | 九九av |