Java架構(gòu)師入門(mén)培訓(xùn)視頻之HashMap

Java架構(gòu)師入門(mén)培訓(xùn)視頻之HashMap

深圳達(dá)內(nèi)教育      2022-04-15 13:42:01     6

Java架構(gòu)師入門(mén)培訓(xùn)視頻之HashMap,HashMap的底層實(shí)現(xiàn)原理HashMap底層實(shí)現(xiàn)采用的是哈希表,一種非常重要的數(shù)據(jù)結(jié)構(gòu)哈希表的基本結(jié)構(gòu)是:數(shù)組+鏈表數(shù)組的特點(diǎn):占用空

課程價(jià)格 請(qǐng)咨詢(xún)

上課時(shí)段: 授課校區(qū):

詳細(xì)介紹

HashMap的底層實(shí)現(xiàn)原理

HashMap底層實(shí)現(xiàn)采用的是哈希表,一種非常重要的數(shù)據(jù)結(jié)構(gòu)

哈希表的基本結(jié)構(gòu)是:數(shù)組+鏈表

數(shù)組的特點(diǎn):占用空間連續(xù),尋址容易,查詢(xún)速度快.但是,增加和刪除的效率非常低

鏈表的特點(diǎn):占用空間不連續(xù),尋址困難,查詢(xún)速度慢.但是,增加和刪除的效率非常高

HashMap源碼兩個(gè)核心內(nèi)容:Entry[]table就是HashMap的核心數(shù)組結(jié)構(gòu),也稱(chēng)之為位桶數(shù)組;Entry對(duì)象是一個(gè)單向鏈表的結(jié)構(gòu),里面存儲(chǔ)了四個(gè)重要的屬性hash,key,value,next

如下圖:

HashMap存儲(chǔ)數(shù)據(jù)的過(guò)程put(key,value)如下:

步驟如下:

1、獲得key對(duì)象的hashcode–首先調(diào)用key對(duì)象的hashcode()方法,獲得hashcode.

2、根據(jù)hashcode計(jì)算出hash值(要求在[0,數(shù)組長(zhǎng)度-1]區(qū)間),hashcode是一個(gè)整數(shù),需要將它轉(zhuǎn)化為[0,數(shù)組長(zhǎng)度-1]的范圍,要求轉(zhuǎn)化后的hash值盡量均勻地分布在[0,數(shù)組長(zhǎng)度-1]這個(gè)區(qū)間,減少"hash沖突".

一種極端簡(jiǎn)單和低下的算法:

hash值=hashcode/hashcode;

也就是說(shuō),hash值總是1,意味著鍵值對(duì)對(duì)象會(huì)存儲(chǔ)到數(shù)組索引1位置,這樣就形成一個(gè)非常長(zhǎng)的鏈表,相當(dāng)于每存儲(chǔ)一個(gè)對(duì)象都會(huì)發(fā)生"hash沖突",HashMap也退化為一個(gè)"鏈表".

一種簡(jiǎn)單和常用的算法是(相除取余算法):

hash值=hashcode%數(shù)組長(zhǎng)度

這種算法可以讓hash值均勻的分布在[0,數(shù)組長(zhǎng)度-1]的區(qū)間,早期的HashTable就是采用這種算法。但是,這種算法由于使用了"除法",效率低下。JDK后來(lái)改進(jìn)了算法,首先約定數(shù)組長(zhǎng)度必須為2的整數(shù)冪,這樣采用位運(yùn)算即可實(shí)現(xiàn)取余的效果:hash值=hashcode&(數(shù)組長(zhǎng)度-1)

public?class?TestHash?{	public?static?void?main(String[]?args)?{		int?hashcode?=?1111;		int?length?=?16;//length為2的整數(shù)冪,則hashcode&(length-1)相當(dāng)于hashcode%length		myhash(hashcode,?length);	}	public?static?void?myhash(int?hashcode,int?length){		//取余		System.out.println(hashcode%length);		//length為2的整數(shù)冪情況下,和取余的值一樣		System.out.println(hashcode&(length-1));	}}

3、生成Entry對(duì)象

一個(gè)Entry對(duì)象包含四個(gè)部分,key對(duì)象、value對(duì)象、hash值、指向下一個(gè)Entry對(duì)象的引用,現(xiàn)在算出了hash值,下一個(gè)Entry對(duì)象的引用為null。

4、將Entry對(duì)象放到table數(shù)組中

如果本Entry對(duì)象對(duì)應(yīng)的數(shù)組索引位置還沒(méi)有放Entry對(duì)象,則直接將Entry對(duì)象存儲(chǔ)進(jìn)數(shù)組,如果對(duì)應(yīng)索引位置已經(jīng)有Entry對(duì)象,則將已有Entry對(duì)象的next指向本Entry對(duì)象,形成鏈表。

深圳達(dá)內(nèi)教育HashMap底層實(shí)現(xiàn)原理視頻教程,快速掌握HashMap技術(shù),強(qiáng)化自身技能:

課程學(xué)習(xí)目錄

1.HashMap底層數(shù)據(jù)結(jié)構(gòu)分析

2.JDK1.7中的HashMap底層實(shí)現(xiàn)分析

3.JDK1.8中的HashMap底層實(shí)現(xiàn)分析

4.HashMap的put操作源碼分析(上)

5.HashMap的put操作源碼分析(下)

6.HashMap的get操作源碼分析

7.HashMap常見(jiàn)面試題分析

8.HashMap底層實(shí)現(xiàn)原理總結(jié)與展望

以上就是對(duì)“Java架構(gòu)師入門(mén)培訓(xùn)視頻之HashMap”的介紹,希望對(duì)大家有所幫助,還想學(xué)習(xí)更多關(guān)于Java的課程,可以關(guān)注深圳達(dá)內(nèi)教育官網(wǎng)Java視頻教程,免費(fèi)下載學(xué)習(xí)。

Java培訓(xùn)視頻

培訓(xùn)啦提醒您:交易時(shí)請(qǐng)核實(shí)對(duì)方資質(zhì),對(duì)于過(guò)大宣傳或承諾需謹(jǐn)慎!任何要求預(yù)付定金、匯款等方式均存在風(fēng)險(xiǎn),謹(jǐn)防上當(dāng)。