Hashcode介紹

Java中的集合(Collection)有兩類(lèi)隐岛,一類(lèi)是List猫妙,再有一類(lèi)是Set。前者集合內(nèi)的元素是有序的聚凹,元素可以重復(fù)割坠;后者元素?zé)o序,但元素不可重復(fù)妒牙。

要想保證元素不重復(fù)彼哼,可兩個(gè)元素是否重復(fù)應(yīng)該依據(jù)什么來(lái)判斷呢?這就是Object.equals方法了湘今。但是敢朱,如果每增加一個(gè)元素就檢查一 次,那么當(dāng)元素很多時(shí)摩瞎,后添加到集合中的元素比較的次數(shù)就非常多了拴签。也就是說(shuō),如果集合中現(xiàn)在已經(jīng)有1000個(gè)元素旗们,那么第1001個(gè)元素加入集合時(shí)蚓哩,它 就要調(diào)用1000次equals方法。這顯然會(huì)大大降低效率上渴。

于是岸梨,Java采用了哈希表的原理。哈希算法也稱(chēng)為散列算法驰贷,是將數(shù)據(jù)依特定算法直接指定到一個(gè)地址上盛嘿。這樣一來(lái),當(dāng)集合要添加新的元素時(shí)括袒,先調(diào)用這個(gè)元素的hashCode方法次兆,就一下子能定位到它應(yīng)該放置的物理位置上。如果這個(gè)位置上沒(méi)有元素锹锰,它就可以 直接存儲(chǔ)在這個(gè)位置上芥炭,不用再進(jìn)行任何比較了漓库;如果這個(gè)位置上已經(jīng)有元素了,就調(diào)用它的equals方法與新元素進(jìn)行比較园蝠,相同的話(huà)就不存了渺蒿;不相同,也就是發(fā)生了Hash key相同導(dǎo)致沖突的情況,那么就在這個(gè)Hash key的地方產(chǎn)生一個(gè)鏈表,將所有產(chǎn)生相同hashcode的對(duì)象放到這個(gè)單鏈表上去,串在一起彪薛。所以這里存在一個(gè)沖突解決的問(wèn)題(很少出現(xiàn))茂装。這樣一來(lái)實(shí)際調(diào)用equals方法的次數(shù)就大大降低了,幾乎只需要一兩次善延。

所以少态,Java對(duì)于eqauls方法和hashCode方法是這樣規(guī)定的:
1、如果兩個(gè)對(duì)象相等易遣,那么它們的hashCode值一定要相等彼妻;
2、如果兩個(gè)對(duì)象的hashCode相等豆茫,它們并不一定相等侨歉。

如何理解hashCode的作用:

以java.lang.Object來(lái)理解,JVM每new一個(gè)Object,它都會(huì)將這個(gè)Object丟到一個(gè)Hash哈希表中去,這樣的話(huà),下次做Object的比較或者取這個(gè)對(duì)象的時(shí)候,它會(huì)根據(jù)對(duì)象的hashcode再?gòu)腍ash表中取這個(gè)對(duì)象。這樣做的目的是提高取對(duì)象的效率揩魂。

具體過(guò)程是這樣:
1.new Object(),JVM根據(jù)這個(gè)對(duì)象的Hashcode值,放入到對(duì)應(yīng)的Hash表對(duì)應(yīng)的Key上,如果不同的對(duì)象確產(chǎn)生了相同的hash值,也就是發(fā)生了Hash key相同導(dǎo)致沖突的情況,那么就在這個(gè)Hash key的地方產(chǎn)生一個(gè)鏈表,將所有產(chǎn)生相同hashcode的對(duì)象放到這個(gè)單鏈表上去,串在一起幽邓。
2.比較兩個(gè)對(duì)象的時(shí)候,首先根據(jù)他們的hashcode去hash表中找他的對(duì)象,當(dāng)兩個(gè)對(duì)象的hashcode相同,那么就是說(shuō)他們這兩個(gè)對(duì)象放在Hash表中的同一個(gè)key上,那么他們一定在這個(gè)key上的鏈表上。那么此時(shí)就只能根據(jù)Object的equal方法來(lái)比較這個(gè)對(duì)象是否equal肤京。當(dāng)兩個(gè)對(duì)象的hashcode不同的話(huà)颊艳,肯定他們不能equal.

改寫(xiě)equals時(shí)總是要改寫(xiě)hashCode茅特。

java.lang.Object中對(duì)hashCode的約定:

  1. 在一個(gè)應(yīng)用程序執(zhí)行期間忘分,如果一個(gè)對(duì)象的equals方法做比較所用到的信息沒(méi)有被修改的話(huà),則對(duì)該對(duì)象調(diào)用hashCode方法多次白修,它必須始終如一地返回同一個(gè)整數(shù)妒峦。
  2. 如果兩個(gè)對(duì)象根據(jù)equals(Object o)方法是相等的,則調(diào)用這兩個(gè)對(duì)象中任一對(duì)象的hashCode方法必須產(chǎn)生相同的整數(shù)結(jié)果兵睛。
  3. 如果兩個(gè)對(duì)象根據(jù)equals(Object o)方法是不相等的肯骇,則調(diào)用這兩個(gè)對(duì)象中任一個(gè)對(duì)象的hashCode方法,不要求產(chǎn)生不同的整數(shù)結(jié)果祖很。但如果能不同笛丙,則可能提高散列表的性能。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末假颇,一起剝皮案震驚了整個(gè)濱河市胚鸯,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌笨鸡,老刑警劉巖姜钳,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件坦冠,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡哥桥,警方通過(guò)查閱死者的電腦和手機(jī)辙浑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)拟糕,“玉大人判呕,你說(shuō)我怎么就攤上這事∷椭停” “怎么了佛玄?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)累澡。 經(jīng)常有香客問(wèn)我梦抢,道長(zhǎng),這世上最難降的妖魔是什么愧哟? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任奥吩,我火速辦了婚禮,結(jié)果婚禮上蕊梧,老公的妹妹穿的比我還像新娘霞赫。我一直安慰自己,他們只是感情好肥矢,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布端衰。 她就那樣靜靜地躺著,像睡著了一般甘改。 火紅的嫁衣襯著肌膚如雪旅东。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,692評(píng)論 1 305
  • 那天十艾,我揣著相機(jī)與錄音抵代,去河邊找鬼。 笑死忘嫉,一個(gè)胖子當(dāng)著我的面吹牛荤牍,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播庆冕,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼康吵,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了访递?” 一聲冷哼從身側(cè)響起晦嵌,我...
    開(kāi)封第一講書(shū)人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后耍铜,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體邑闺,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年棕兼,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了陡舅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡伴挚,死狀恐怖靶衍,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情茎芋,我是刑警寧澤颅眶,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站田弥,受9級(jí)特大地震影響涛酗,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜偷厦,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一商叹、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧只泼,春花似錦剖笙、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至十绑,卻和暖如春聚至,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背孽惰。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工晚岭, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人勋功。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像库说,于是被迫代替她去往敵國(guó)和親狂鞋。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 一、基本數(shù)據(jù)類(lèi)型 注釋 單行注釋?zhuān)?/ 區(qū)域注釋?zhuān)?* */ 文檔注釋?zhuān)?** */ 數(shù)值 對(duì)于byte類(lèi)型而言...
    龍貓小爺閱讀 4,265評(píng)論 0 16
  • 9/21【每日一結(jié)構(gòu)】結(jié)構(gòu)思考力21天思維改善訓(xùn)練營(yíng) G:【擺脫被手機(jī)“綁架”】把手機(jī)放到一個(gè)適當(dāng)?shù)奈恢貌⑶腋玫?..
    一只永不止步的龍閱讀 290評(píng)論 0 0
  • 陽(yáng)光像多情風(fēng)流的女子,總是在你晨勃的時(shí)候偷偷來(lái)到你的床上信不,親吻你裸露在外的每一寸肌膚嘲叔,把你從'夢(mèng)'的手里搶奪過(guò)來(lái)。...
    落筆生灰閱讀 333評(píng)論 0 2
  • [cp][ 我想畫(huà)下遙遠(yuǎn)的風(fēng)景抽活,畫(huà)下清晰的地平線(xiàn)和山巒硫戈,畫(huà)下許多許多快樂(lè)的小河,我還想畫(huà)下你的面容和我們的未來(lái) ]...
    攝影師心一閱讀 112評(píng)論 0 0
  • 懷念堂弟 總以為相聚的日子很多下硕, 因?yàn)槲覀冞€年輕丁逝。 但當(dāng)你年輕的生命戛然而止與冰冷的車(chē)輪下, 鮮血悲傷...
    遠(yuǎn)方的蒲葦閱讀 255評(píng)論 0 0