麻豆黑色丝袜jk制服福利网站-麻豆精品传媒视频观看-麻豆精品传媒一二三区在线视频-麻豆精选传媒4区2021-在线视频99-在线视频a

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > ConcurrentHashMap和Hashtable的區(qū)別?

ConcurrentHashMap和Hashtable的區(qū)別?

來源:千鋒教育
發(fā)布人:wjy
時間: 2022-09-19 11:38:12 1663558692

  ConcurrentHashMap 和 Hashtable 的區(qū)別主要體現(xiàn)在實現(xiàn)線程安全的方式上不同。

  1. 底層數(shù)據(jù)結(jié)構(gòu): JDK1.7的 ConcurrentHashMap 底層采用 分段的數(shù)組+鏈表 實現(xiàn),JDK1.8 采用的數(shù)據(jù)結(jié)構(gòu)跟HashMap1.8的結(jié)構(gòu)一樣,數(shù)組+鏈表/紅黑二叉樹。Hashtable 和 JDK1.8 之前的 HashMap 的底層數(shù)據(jù)結(jié)構(gòu)類似都是采用 數(shù)組+鏈表 的形式,數(shù)組是 HashMap 的主體,鏈表則是主要為了解決哈希沖突而存在的;

  2. 實現(xiàn)線程安全的方式:

  ① 在JDK1.7的時候,ConcurrentHashMap(分段鎖) 對整個桶數(shù)組進(jìn)行了分割分段(Segment),每一把鎖只鎖容器其中一部分?jǐn)?shù)據(jù),多線程訪問容器里不同數(shù)據(jù)段的數(shù)據(jù),就不會存在鎖競爭,提高并發(fā)訪問率。(默認(rèn)分配16個Segment,比Hashtable效率提高16倍。) 到了 JDK1.8 的時候已經(jīng)摒棄了Segment的概念,而是直接用 Node 數(shù)組+鏈表+紅黑樹的數(shù)據(jù)結(jié)構(gòu)來實現(xiàn),并發(fā)控制使用 synchronized 和 CAS 來操作。(JDK1.6以后 對 synchronized鎖做了很多優(yōu)化) 整個看起來就像是優(yōu)化過且線程安全的 HashMap,雖然在JDK1.8中還能看到 Segment 的數(shù)據(jù)結(jié)構(gòu),但是已經(jīng)簡化了屬性,只是為了兼容舊版本;

  ② Hashtable(同一把鎖) :使用 synchronized 來保證線程安全,效率非常低下。當(dāng)一個線程訪問同步方法時,其他線程也訪問同步方法,可能會進(jìn)入阻塞或輪詢狀態(tài),如使用 put 添加元素,另一個線程不能使用 put 添加元素,也不能使用 get,競爭會越來越激烈效率越低。

  3. 兩者的對比圖:

  ①HashTable:

ConcurrentHashMap和Hashtable的區(qū)別1

 

  ② JDK1.7的ConcurrentHashMap:

ConcurrentHashMap和Hashtable的區(qū)別2

 

  ③ JDK1.8的ConcurrentHashMap(TreeBin: 紅黑二叉樹節(jié)點(diǎn) Node: 鏈表節(jié)點(diǎn)):

ConcurrentHashMap和Hashtable的區(qū)別3

 

  ConcurrentHashMap 結(jié)合了 HashMap 和 HashTable 二者的優(yōu)勢。HashMap 沒有考慮同步,HashTable 考慮了同步的問題使用了synchronized 關(guān)鍵字,所以 HashTable 在每次同步執(zhí)行時都要鎖住整個結(jié)構(gòu)。 ConcurrentHashMap 鎖的方式是稍微細(xì)粒度的。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
快速通道
主站蜘蛛池模板: 免费在线观看国产| 蜜桃97爱成人| 欧美人善交videosg| 国产老师的丝袜在线看| 国产精品久久一区二区三区 | 天天av天天翘天天综合网| 国产高清露脸| 免费人成在线观看视频播放| 三级一级片| 足本玉蒲团在线观看| 好男人影视官网在线www| 3p视频在线| 多人交换伦交视频| 啊轻点灬大巴太粗太长了视频| 久久亚洲伊人中字综合精品| 毛片无码国产| 国产嫩草影院精品免费网址| 一个妈妈的女儿在线观看5| 正在播放julia女教师| 182在线播放| 2021天天操| а√天堂中文最新版地址| 中日韩精品视频在线观看| 亚洲国产欧美日韩精品一区二区三区| 男女性潮高清免费网站| 国产午夜精品一区二区三区| 中文字幕精品一区二区精品| 好吊操在线视频| 国内国外精品影片无人区| 么公的好大好深视频好爽想要 | 日本公与熄乱理在线播放370| 桃花影院www视频播放| 动漫痴汉电车1~6集在线| 豪妇荡乳1一5| 日本在线免费看片| 欧美日韩电影网| 在线观看国产小屁孩cao大人| 国产又色又爽在线观看| 污网站视频在线观看| 成人午夜小视频| 久久66热这里只会有精品|