国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

瀏覽:142日期: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)) {//這一句會存在并發(fā)問題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();; }}}

輸出結(jié)果:

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

表明了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函數(shù)中包含了多次操作,ConcurrentMap沒法擴大它的同步范圍,你需要自己實現(xiàn)getLock的鎖。

回答3:

使用putIfAbsent方法。

標簽: java
相關(guān)文章:
主站蜘蛛池模板: 日韩天天摸天天澡天天爽视频 | 日韩黄在线观看免费视频 | 亚洲天堂日韩在线 | 91亚洲精品一区二区在线观看 | 久久er国产精品免费观看1 | 亚洲免费片 | 久久亚洲精品成人 | 久久精品一区二区三区四区 | 午夜三级在线 | wwww亚洲| 欧美成人高清性色生活 | 国产精品合集一区二区 | 国产日韩欧美亚洲 | 国产在线观看精品 | 久草在线视频免费 | a一级爱做片免费 | 日韩欧美一区二区精品久久 | 久久精品国内一区二区三区 | 久久精品人人爽人人爽快 | 国产一级毛片午夜 | 97免费视频观看 | 在线观看免费黄色网址 | 亚洲天堂在线视频观看 | 天堂1在线观看 | 欧美一级成人免费大片 | 成人免费网站视频 | 在线观看一区二区三区视频 | 兔子先生节目在线观看免费 | 国产成人理在线观看视频 | 国产精品亚洲精品一区二区三区 | 华人黄网站 | 久久精品久久精品国产大片 | 国产91精品露脸国语对白 | 国产乱淫a∨片免费视频 | 亚洲成a人片 | 99re国产视频 | 成年人三级视频 | 美国一级大黄香蕉片 | 99久久99久久精品免费看子 | 一级毛片在线完整免费观看 | 国内精品久久久久久网站 |