亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

java - ConcurrentHashMap中的get()方法為什么可以不加鎖?

瀏覽:114日期:2023-12-13 16:07:45

問題描述

public V get(Object key) {Segment<K,V> s; // manually integrate access methods to reduce overheadHashEntry<K,V>[] tab;int h = hash(key);long u = (((h >>> segmentShift) & segmentMask) << SSHIFT) + SBASE;if ((s = (Segment<K,V>)UNSAFE.getObjectVolatile(segments, u)) != null && (tab = s.table) != null) { for (HashEntry<K,V> e = (HashEntry<K,V>) UNSAFE.getObjectVolatile (tab, ((long)(((tab.length - 1) & h)) << TSHIFT) + TBASE); e != null; e = e.next) {K k;if ((k = e.key) == key || (e.hash == h && key.equals(k))) return e.value; }}return null; }

為什么Vector的get就需要使用synchronized來加鎖而ConcurrentHashMap則不需要?而且CopyOnWriteArrayList也是使用了寫時復制還能實現讀寫并行,而顯然ConcrrentHashMap并沒有實現寫時復制,它是怎么保證讀寫并行時不會讀取到不一致中間狀態的呢?

問題解答

回答1:

這篇文章解釋的挺好的

標簽: java
相關文章:
主站蜘蛛池模板: 欧美一级做一级爱a做片性 欧美一级做一级做片性十三 | 成人啪精品视频免费网站 | 欧美精品区| 欧美成人免费tv在线播放 | 欧美精品综合一区二区三区 | 色综合久久中文综合网 | 欧美精品亚洲精品日韩经典 | 婷婷草| 国内精品视频在线播放一区 | 国产亚洲精品美女一区二区 | 久久精品爱 | 国产精品久久久久乳精品爆 | 91香蕉视频在线观看 | 国产偷2018在线观看午夜 | 欧美换爱交换乱理伦片不卡片 | 不卡一区在线观看 | 美女网站免费久久久久久久 | 亚洲一区二区在线 | 中文字幕在线视频网 | 黄色片免费观看网站 | 免费日本黄色 | 亚洲精品精品一区 | 亚洲综合视频在线观看 | 亚洲国产第一 | 日本免费人成黄页在线观看视频 | 中国免费黄色片 | 国产精品区一区二区三 | 国产精品久久久久久久久久久不卡 | 精品综合一区二区三区 | 国产狂喷白浆在线观看视频 | 国产在线一二三区 | 尤物精品视频在线观看 | 57pao一国产成视频永久免费 | 免费的黄色网址 | 成人精品一区二区久久 | 国产乱理伦片a级在线观看 国产乱理伦片在线观看 | 久久视热这只是精品222 | 999国产精品999久久久久久 | 久久青草免费线观最新 | 乱人伦精品一区二区 | 日本不卡中文字幕一区二区 |