要实现ConcurrentHashMap的线程安全性,可以使用synchronized关键字来保证代码块的互斥执行,从而避免多线程同时对ConcurrentHashMap进行写操作。
以下是一个示例代码:
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
public class ConcurrentHashMapDemo {
private Map map = new ConcurrentHashMap<>();
public void put(String key, Integer value) {
synchronized (map) {
if (!map.containsKey(key)) {
map.put(key, value);
}
}
}
public Integer get(String key) {
return map.get(key);
}
public static void main(String[] args) {
ConcurrentHashMapDemo demo = new ConcurrentHashMapDemo();
Thread t1 = new Thread(() -> {
for (int i = 0; i < 1000; i++) {
demo.put("key", i);
}
});
Thread t2 = new Thread(() -> {
for (int i = 0; i < 1000; i++) {
demo.put("key", i);
}
});
t1.start();
t2.start();
try {
t1.join();
t2.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(demo.get("key")); // 输出999
}
}
在上面的示例中,我们使用synchronized关键字对put方法进行了同步操作,确保在多线程环境下只有一个线程能够执行put操作。这样就能够保证ConcurrentHashMap的线程安全性。