这里的一定线程安全指的是绝对安全。
下面直接上代码:
package com.testconcurrent;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class ChmTest2 {
public static void main(String[] args) {
final ConcurrentHashMap<Integer, String> chm = new ConcurrentHashMap<Integer, String>();
ExecutorService newFixedThreadPool = Executors.newFixedThreadPool(10);
newFixedThreadPool.submit(new Runnable() {
public void run() {
for(int i = 0;i <1000000;i++){
chm.put(123, "asd"+i);
}
}
});
newFixedThreadPool.submit(new Runnable() {
public void run() {
System.out.println(chm.get(123));
}
});
newFixedThreadPool.shutdown();
}
}
通过多次运行发现,每次get的值都是不一样的,但如果保证get值一样的,那么就考虑串行了。
所以说,所有的安全容器只能保证相对安全,不能保证绝对安全。以上是我的一点小思考。
本文通过示例代码展示了ConcurrentHashMap在并发环境下的行为,并指出即使在使用线程安全容器时,也不能完全避免数据一致性问题。文章强调了线程安全的相对性。

8375





