Map线程安全几种实现方法
2014-03-06 13:18
316 查看
如果需要使 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();
这样两个读操作可以同时进行,理论上效率会比方法 2 高。
4、使用 JDK1.5 提供的 java.util.concurrent.ConcurrentHashMap 类。该类将 Map 的存储空间分为若干块,每块拥有自己的锁,大大减少了多个线程争夺同一个锁的情况。代码如下
value = map.get(key); //同步机制内置在 get 方法中
比较:
1、不同步确实最快,与预期一致。
2、四种同步方式中,ConcurrentHashMap 是最快的,接近不同步的情况。
3、synchronized 关键字非常慢,比使用锁慢了两个数量级。如果需自己实现同步,则使用 JDK1.5 提供的锁机制,避免使用 synchronized 关键字。
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();
这样两个读操作可以同时进行,理论上效率会比方法 2 高。
4、使用 JDK1.5 提供的 java.util.concurrent.ConcurrentHashMap 类。该类将 Map 的存储空间分为若干块,每块拥有自己的锁,大大减少了多个线程争夺同一个锁的情况。代码如下
value = map.get(key); //同步机制内置在 get 方法中
比较:
1、不同步确实最快,与预期一致。
2、四种同步方式中,ConcurrentHashMap 是最快的,接近不同步的情况。
3、synchronized 关键字非常慢,比使用锁慢了两个数量级。如果需自己实现同步,则使用 JDK1.5 提供的锁机制,避免使用 synchronized 关键字。
相关文章推荐
- Map线程安全几种实现方法
- Map线程安全几种实现方法
- Map线程安全几种实现方法
- Map线程安全几种实现方法
- Map线程安全几种实现方法
- Java集合中那些类是线程安全的 以及 Map线程安全几种实现方法
- Map线程安全几种实现方法
- Map线程安全几种实现方法
- 线程安全的概念,实现线程安全的几种方法
- 几个问题(三)--------线程安全的概念,实现线程安全的几种方法
- JAVA遍历map的几种实现方法代码
- 关于Map线程安全的几种实现方案
- 线程安全的单例模式的几种实现方法分享
- java实现同步map的几种方法(lock,synchronized,rwlock,ConcurrentHashMap,hashtable,SynchronizedMap)
- 线程安全的概念,实现线程安全的几种方法
- 线程安全的概念,实现线程安全的几种方法
- 几个问题(三)--------线程安全的概念,实现线程安全的几种方法
- 线程安全的单例模式的几种实现方法分享
- 线程安全的概念,实现线程安全的几种方法
- Java 实现 Map 和 Object 互相转换的几种方法