日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Java源碼解析之ConcurrentHashMap

瀏覽:173日期:2022-08-11 17:31:33

早期 ConcurrentHashMap,其實(shí)現(xiàn)是基于:

分離鎖,也就是將內(nèi)部進(jìn)行分段(Segment),里面則是 HashEntry 的數(shù)組,和 HashMap 類似,哈希相同的條目也是以鏈表形式存放。 HashEntry 內(nèi)部使用 volatile 的 value 字段來保證可見性,也利用了不可變對(duì)象的機(jī)制以改進(jìn)利用 Unsafe 提供的底層能力,比如 volatile access,去直接完成部分操作,以最優(yōu)化性能,畢竟 Unsafe 中的很多操作都是 JVM intrinsic 優(yōu)化過的。

在進(jìn)行并發(fā)操作的時(shí)候,只需要鎖定相應(yīng)段,這樣就有效避免了類似 Hashtable 整體同步的問題,大大提高了性能。

Java源碼解析之ConcurrentHashMap

Put操作

通過二次哈希避免哈希沖突,然后以 Unsafe 調(diào)用方式,直接獲取相應(yīng)的 Segment,然后進(jìn)行線程安全的 put 操作

public V put(K key, V value) { Segment<K,V> s; if (value == null) throw new NullPointerException(); // 二次哈希,以保證數(shù)據(jù)的分散性,避免哈希沖突 int hash = hash(key.hashCode()); int j = (hash >>> segmentShift) & segmentMask; if ((s = (Segment<K,V>)UNSAFE.getObject // nonvolatile; recheck (segments, (j << SSHIFT) + SBASE)) == null) // in ensureSegment s = ensureSegment(j); return s.put(key, hash, value, false); }

其核心邏輯實(shí)現(xiàn)在下面的內(nèi)部方法中:

final V put(K key, int hash, V value, boolean onlyIfAbsent) { // scanAndLockForPut 會(huì)去查找是否有 key 相同 Node // 無論如何,確保獲取鎖 HashEntry<K,V> node = tryLock() ? null : scanAndLockForPut(key, hash, value); V oldValue; try { HashEntry<K,V>[] tab = table; int index = (tab.length - 1) & hash; HashEntry<K,V> first = entryAt(tab, index); for (HashEntry<K,V> e = first;;) { if (e != null) { K k; // 更新已有 value... } else { // 放置 HashEntry 到特定位置,如果超過閾值,進(jìn)行 rehash // ... } } } finally { unlock(); } return oldValue; }

在寫的時(shí)候:

ConcurrentHashMap 會(huì)獲取再入鎖,以保證數(shù)據(jù)一致性,Segment 本身就是基于 ReentrantLock 的擴(kuò)展實(shí)現(xiàn),所以,在并發(fā)修改期間,相應(yīng) Segment 是被鎖定的。 在最初階段,進(jìn)行重復(fù)性的掃描,以確定相應(yīng) key 值是否已經(jīng)在數(shù)組里面,進(jìn)而決定是更新還是放置操作。 在 ConcurrentHashMap 中解決擴(kuò)容的問題,不是整體的擴(kuò)容,而是單獨(dú)對(duì) Segment 進(jìn)行擴(kuò)容。 為了減少鎖定segment的開銷,ConcurrentHashMap 的實(shí)現(xiàn)是通過重試機(jī)制(RETRIES_BEFORE_LOCK,指定重試次數(shù) 2),來試圖獲得可靠值。如果沒有監(jiān)控到發(fā)生變化(通過對(duì)比 Segment.modCount),就直接返回,否則獲取鎖進(jìn)行操作。

機(jī)制在Java 8 上的變化:

總體結(jié)構(gòu)上,它的內(nèi)部存儲(chǔ)與HashMap 結(jié)構(gòu)非常相似,同樣是大的桶(bucket)數(shù)組,然后內(nèi)部也是一個(gè)個(gè)所謂的鏈表結(jié)構(gòu)(bin),同步的粒度要更細(xì)致一些。 其內(nèi)部仍然有 Segment 定義,但僅僅是為了保證序列化時(shí)的兼容性而已,不再有任何結(jié)構(gòu)上的用處。 因?yàn)椴辉偈褂?Segment,初始化操作大大簡化,修改為 lazy-load 形式,這樣可以有效避免初始開銷。 數(shù)據(jù)存儲(chǔ)利用 volatile 來保證可見性。 使用 CAS (Compare And Swap)等操作,在特定場景進(jìn)行無鎖并發(fā)操作。 使用 Unsafe、LongAdder 之類底層手段,進(jìn)行極端情況的優(yōu)化。

看看在java8上的put操作

final V putVal(K key, V value, boolean onlyIfAbsent) { if (key == null || value == null) throw new NullPointerException(); int hash = spread(key.hashCode()); int binCount = 0; for (Node<K,V>[] tab = table;;) { Node<K,V> f; int n, i, fh; K fk; V fv; if (tab == null || (n = tab.length) == 0) tab = initTable(); else if ((f = tabAt(tab, i = (n - 1) & hash)) == null) { // 利用 CAS 去進(jìn)行無鎖線程安全操作,如果 bin 是空的 if (casTabAt(tab, i, null, new Node<K,V>(hash, key, value))) break; } else if ((fh = f.hash) == MOVED) tab = helpTransfer(tab, f); else if (onlyIfAbsent // 不加鎖,進(jìn)行檢查 && fh == hash && ((fk = f.key) == key || (fk != null && key.equals(fk))) && (fv = f.val) != null) return fv; else { V oldVal = null; synchronized (f) { // 細(xì)粒度的同步修改操作... } } // Bin 超過閾值,進(jìn)行樹化 if (binCount != 0) { if (binCount >= TREEIFY_THRESHOLD) treeifyBin(tab, i); if (oldVal != null) return oldVal; break; } } } addCount(1L, binCount); return null; }

初始化操作實(shí)現(xiàn)在 initTable 里面,這是一個(gè)典型的 CAS 使用場景,利用 volatile 的 sizeCtl 作為互斥手段:如果發(fā)現(xiàn)競爭性的初始化,就 spin 在那里,等待條件恢復(fù);否則利用 CAS 設(shè)置排他標(biāo)志。如果成功則進(jìn)行初始化;否則重試。

private final Node<K,V>[] initTable() { Node<K,V>[] tab; int sc; while ((tab = table) == null || tab.length == 0) { // 如果發(fā)現(xiàn)沖突,進(jìn)行 spin 等待 if ((sc = sizeCtl) < 0) Thread.yield(); // CAS 成功返回 true,則進(jìn)入真正的初始化邏輯 else if (U.compareAndSetInt(this, SIZECTL, sc, -1)) { try { if ((tab = table) == null || tab.length == 0) { int n = (sc > 0) ? sc : DEFAULT_CAPACITY; @SuppressWarnings('unchecked') Node<K,V>[] nt = (Node<K,V>[])new Node<?,?>[n]; table = tab = nt; sc = n - (n >>> 2); } } finally { sizeCtl = sc; } break; } } return tab; }

當(dāng) bin 為空時(shí),同樣是沒有必要鎖定,也是以 CAS 操作去放置。

到此這篇關(guān)于Java源碼解析之ConcurrentHashMap的文章就介紹到這了,更多相關(guān)Java ConcurrentHashMap內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品女主播一区二区三区| 麻豆一区二区三| 亚洲日本在线观看视频| 五月天久久久| 午夜欧美理论片| 亚洲综合日本| 亚洲精品乱码久久久久久蜜桃麻豆| 综合日韩在线| 青青国产精品| 国产精品久久久久久久久久久久久久久 | 日韩欧美另类一区二区| 97国产成人高清在线观看| 精品日韩视频| 中文一区二区| 久久狠狠久久| av在线最新| 五月婷婷六月综合| 亚洲综合精品| 日韩一二三区在线观看| 国产欧美日韩一区二区三区四区| 日韩av一区二区在线影视| 中文字幕日韩高清在线| 美女久久一区| 亚洲激精日韩激精欧美精品| 亚洲欧美网站| 亚洲精品亚洲人成在线观看| 日韩av中文字幕一区二区| 国产日产一区| 久久精品三级| 日韩大片在线| 黑丝美女一区二区| 免费日韩一区二区| 日本不卡视频一二三区| 国产精品午夜av| 国产一区二区三区国产精品| 成人在线视频区| 久久亚洲国产精品尤物| 狂野欧美性猛交xxxx| 精品久久97| 日韩在线观看一区| 欧美日韩国产在线观看网站| 亚洲一区二区成人| 欧美在线看片| 国产精品二区不卡| 99精品视频精品精品视频| 午夜精品婷婷| 欧美视频精品全部免费观看| 精品国产欧美日韩| 欧美特黄一区| 国产区精品区| 久久精品91| 中文日韩在线| 国产精品久久久久毛片大屁完整版| 毛片在线网站| 亚洲欧洲日韩精品在线| 国产精久久久| 欧美日韩免费观看一区=区三区 | 日韩一级网站| 欧美日韩亚洲三区| 高清不卡亚洲| 在线免费观看亚洲| 国产一区二区三区四区五区 | 欧美视频一区| 亚洲第一精品影视| 欧美日韩99| 午夜国产一区二区| 国产日韩精品视频一区二区三区| 欧美日韩在线播放视频| 国产伦理一区| 久久夜色精品| av高清一区| 国产精品分类| 香蕉久久久久久久av网站| 亚洲人www| 日韩一区二区三区精品视频第3页 日韩一区二区三区免费视频 | 中文久久精品| 精品国产午夜肉伦伦影院| 欧美精品激情| 成人综合一区| 日韩国产精品久久久久久亚洲| 日韩精品电影| 国产精品久久久网站| 日韩中文字幕av电影| 国产日韩在线观看视频| 久久伦理在线| 久久av影院| 欧美成人基地| 开心激情综合| 青青草国产精品亚洲专区无| 日韩国产一区二区三区| 欧美日韩精品一区二区三区在线观看| 波多野结衣一区| 国产中文字幕一区二区三区| 日韩三级久久| 日韩午夜一区| 欧美不卡在线| 成人午夜精品| 丰满少妇一区| 麻豆成人av在线| 日本高清久久| 亚洲三级网站| 免费成人av在线播放| 精品一区在线| 日韩免费小视频| 久久99性xxx老妇胖精品| 日韩av不卡一区二区| 玖玖精品视频| 亚洲美洲欧洲综合国产一区| 视频小说一区二区| 国产精品久久久久av蜜臀| 日韩影院精彩在线| 男人的天堂久久精品| 中文字幕在线免费观看视频| 国产精品一区亚洲| 欧美亚洲专区| 欧美日韩夜夜| 国产精品日本一区二区不卡视频| 欧美一区成人| 国产亚洲高清在线观看| 亚洲精品少妇| 视频一区日韩精品| 亚洲日本欧美| 日韩精品免费视频人成| 亚洲精品四区| 日韩精品三级| 欧美日韩一视频区二区| 亚洲人成毛片在线播放女女| 六月婷婷一区| 伊人www22综合色| 视频一区中文字幕精品| 青青国产精品| 国产精一区二区| 精品五月天堂| 成人va天堂| 亚洲美女久久| 久久国产精品免费精品3p| 国产精品2023| 国产精品欧美大片| 国产精品sss在线观看av| 国产精品嫩草99av在线| 性色一区二区| 老司机久久99久久精品播放免费| 一区二区国产精品| 亚洲1区在线观看| 97精品久久| 精品在线网站观看| 日本高清不卡一区二区三区视频| 久久免费大视频| 久久高清免费观看| 亚洲欧洲美洲国产香蕉| 婷婷成人av| 欧美成人精品午夜一区二区| 91av亚洲| 亚洲欧美日韩综合国产aⅴ| 日韩**一区毛片| 国产欧美高清视频在线| 国产专区精品| 亚洲欧美综合| 亚洲精品三级| 精品视频一区二区三区四区五区| 亚洲一区资源| 蜜桃视频一区二区| 日韩av三区| 日韩精品免费一区二区在线观看 | 亚洲精品网址| 91成人在线网站| 高清久久一区| 亚洲免费中文| 麻豆视频一区二区| 亚洲高清二区| 日本不卡视频在线观看| 麻豆mv在线观看| 亚洲一二av| 卡一精品卡二卡三网站乱码| 午夜影院一区| 四虎成人精品一区二区免费网站| 国产精品久久乐| 99成人在线视频| 久久国产免费看| 日本久久成人网| 欧美色综合网| 亚洲精品午夜av福利久久蜜桃| 国产精品伦一区二区| 黄色av一区| 高清精品久久| 亚洲人成网站在线在线观看| 国产一区三区在线播放| 国产精品免费看| 六月婷婷综合| 久久国际精品| 欧美日韩水蜜桃| 国产精品一区二区三区四区在线观看 | 99国产精品久久久久久久成人热| 美日韩一区二区三区| 男女性色大片免费观看一区二区| 精品少妇av| 日本少妇一区二区| 亚洲调教视频在线观看| 欧美精品导航| 九色精品91|