java map 线程安全_Map线程安全的四种实现方法

Map 线程安全四种方法:

1、使用 synchronized 关键字,代码如下

synchronized(anObject) {

value=map.get(key);

}

2、使用 JDK1.5提供的锁(java.util.concurrent.locks.Lock)

lock.lock();

value=map.get(key);

lock.unlock();

3、使用 JDK1.5 提供的读写锁(java.util.concurrent.locks.ReadWriteLock)

rwlock.readLock().lock();

value=map.get(key);

rwlock.readLock().unlock();

4、使用 JDK1.5 提供的 java.util.concurrent.ConcurrentHashMap(并发哈希) 类。该类将 Map 的存储空间分为若干块,每块拥有自己的锁,减少了多个线程争夺同一个锁的情况。

Map conMap = new ConcurrentHashMap();

比较:

1、不同步确实最快,与预期一致。

2、四种同步方式中,ConcurrentHashMap 是最快的,接近不同步的情况。

3、synchronized 关键字非常慢,比使用锁慢了两个数量级。如果需自己实现同步,则使用 JDK1.5 提供的锁机制,避免使用 synchronized 关键字。

Map 线程安全四种方法: 1、使用 synchronized 关键字,代码如下 synchronized(anObject) { value=map.get(key); } 2、使用 JDK1.5提供的锁(java.util.concurrent.locks.Lock) lock.lock(); value=map.get(key); lock.unlock(); 3、使用 JDK1.5 提供的读写锁(java.util.concurrent.locks.ReadWriteLock) rwlock.readLock().lock(); value=map.get(key); rwlock.readLock().unlock(); 4、使用 JDK1.5 提供的 java.util.concurrent.ConcurrentHashMap(并发哈希) 类。该类将 Map 的存储空间分为若干块,每块拥有自己的锁,减少了多个线程争夺同一个锁的情况。 Map conMap = new ConcurrentHashMap(); 比较: 1、不同步确实最快,与预期一致。 2、四种同步方式中,ConcurrentHashMap 是最快的,接近不同步的情况。 3、synchronized 关键字非常慢,比使用锁慢了两个数量级。如果需自己实现同步,则使用 JDK1.5 提供的锁机制,避免使用 synchronized 关键字。
经验分享 程序员 微信小程序 职场和发展