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

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

java - 多線程并發情況下Map.containsKey() 判斷有問題

瀏覽:101日期:2024-01-27 16:23:18

問題描述

有下面一段代碼:

package test;import java.util.concurrent.ConcurrentHashMap;import java.util.concurrent.ConcurrentMap;public class TestContain extends Thread{ private final String key = 'key'; private final static ConcurrentMap<String, Object> locks = new ConcurrentHashMap<>();private static Object getLock(String lockName) { if (!locks.containsKey(lockName)) {//這一句會存在并發問題locks.put(lockName, new String('我是值'));System.out.println('加了一次'); } return locks.get(lockName);}@Overridepublic void run() { getLock(this.key);};public static void main(String[] args) { for (int i = 0; i < 20; i++) {new TestContain().start();; }}}

輸出結果:

加了一次加了一次加了一次

表明了Map.containsKey() 在多線程的情況下會判斷不準確。

這是為什么呢? 有什么方法改進呢?

問題解答

回答1:

ConcurrentHashMap的doc上有一段

Retrieval operations (including <tt>get</tt>) generally do not block, so may overlap with update operations (including

<tt>put</tt> and <tt>remove</tt>). Retrievals reflect the results of the most recently completed update operations holding upon their onset.

里面的get方法并不加鎖,get方法只是拿到最新完成update的值。

所以題主方法中的locks.containsKey(lockName)沒有鎖來保證線程安全的。而且感覺ConcurrentHashMap的使用場景并不是用containsKey來保證更新操作只進行一次,而是用putIfAbsent來保證。

回答2:

ConcurrentMap保證的是單次操作的原子性,而不是多次操作。

你的getLock函數中包含了多次操作,ConcurrentMap沒法擴大它的同步范圍,你需要自己實現getLock的鎖。

回答3:

使用putIfAbsent方法。

標簽: java
相關文章:
主站蜘蛛池模板: 欧美综合在线观看 | 一级特黄录像免费播放冫 | 日本三级韩国三级三级a级按摩 | 国产免费观看a大片的网站 国产免费观看网站黄页 | 日本护士一级毛片在线播放 | 精品国产免费观看一区高清 | 国产caoni111在线观看视频 | ssss国产在线观看 | 亚州va| 久久精品一区二区三区四区 | 亚洲一区二区欧美日韩 | 中日韩美中文字幕 | 欧美三级欧美做a爱 | 日韩欧美视频在线 | 一级做a爱过程视频免 | 日韩精品国产一区 | 国产亚洲欧美在线 | 九九夜夜| 欧美ol丝袜高跟秘书在线观看 | 成人免费淫片95视频观看网站 | 制服丝袜中文字幕第一页 | 亚洲免费片 | 黄色免费一级播放片 | 色涩在线观看 | 999久久久国产精品 999久久久精品视频在线观看 | 午夜特级毛片 | 日本国产欧美色综合 | 成人一区专区在线观看 | 国产一级毛片夜一级毛片 | 毛片xxxx| 欧美一级www片免费观看 | 日韩a级大片 | 国产手机精品自拍视频 | 欧美成熟videos老妇 | 欧美成人性色大片在线观看 | 国产三级一区 | www.中文字幕在线 | 色偷偷亚洲女人天堂观看欧 | 综合天天 | 成人国产精品一级毛片视频 | 欧美一级欧美三级在线观看 |