总结:各种加锁方法对于Map .(转)

转载 2015年11月19日 17:31:20
 hashmap是不带有锁的,hashtable是带有锁的,多线程使用过程中,需要对hashmap加锁,可以用

1.使用 synchronized 关键字,这也是最原始的方法。代码如下

synchronized(anObject)  {   

     value = map.get(key);

}  

2.使用 JDK1.5 提供的锁(java.util.concurrent.locks.Lock)。代码如下2.

Java代码 复制代码
  1. lock.lock();   
  2. value = map.get(key);   
  3. lock.unlock();  

3.这样处理时对于hashmap的读写都加锁了,但是如果涉及到少量插入及频繁的查找,那么上面两种的效率不是很高,这时候最好的方式是加读写锁。以下为构造读写锁包装map的方法:

  1. <SPAN style="FONT-SIZE: 18px">import java.util.Map;  
  2. import java.util.concurrent.locks.Lock;  
  3. import java.util.concurrent.locks.ReadWriteLock;  
  4. import java.util.concurrent.locks.ReentrantReadWriteLock;  
  5.   
  6. public class ReadWriteMap<K, V> {  
  7.     private final Map<K, V> map;  
  8.     private final ReadWriteLock lock = new ReentrantReadWriteLock();  
  9.     private final Lock r = lock.readLock();  
  10.     private final Lock w = lock.writeLock();  
  11.   
  12.     public ReadWriteMap(Map<K, V> map) {  
  13.         this.map = map;  
  14.     }  
  15.   
  16.     public V put(K key, V value) {  
  17.         w.lock();  
  18.         try {  
  19.             return map.put(key, value);  
  20.         } finally {  
  21.             w.unlock();  
  22.         }  
  23.     }  
  24.   
  25.     public V get(Object key) {  
  26.         r.lock();  
  27.         try {  
  28.             return map.get(key);  
  29.         } finally {  
  30.             r.unlock();  
  31.         }  
  32.     }  
  33. }</SPAN>  


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

value = map.get(key); //同步机制内置在 get 方法中

这种方式最快


结论: 

1、如果 ConcurrentHashMap 够用,则使用 ConcurrentHashMap。 

2、如果需自己实现同步,则使用 JDK1.5 提供的锁机制,避免使用 synchronized 关键字。

相关文章推荐

总结:各种加锁方法对于Map

hashmap是不带有锁的,hashtable是带有锁的,多线程使用过程中,需要对hashmap加锁,可以用 1.使用 synchronized 关键字,这也是最原始的方法。代码如下 synchr...

【Java并发编程】之十五:并发编程中实现内存可见的两种方法比较:加锁和volatile变量

并发编程中实现内存可见的两种方法比较:加锁和volatile变量

java加锁与同步方法

记下来,很重要。 Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码。      一、当两个并发线程访问同一个对象object中的这个...

java加锁与同步方法

Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码。一、当两个并发线程访问同一个对象object中的这个synchronized(this)...

IOS中实现线程加锁的几个方法

转载自: http://www.tanhao.me/tag/nslock Objective-C中不同方式实现锁(一) 为什么需要使用锁,当然熟悉多线程的你,自然不会对它觉得陌...

SVN版本冲突的解决方法(非加锁)

SVN版本冲突的解决方法(非加锁) 版本冲突原因: 加入A、B两个用户都在版本为10的时候更新了file.txt这个文件,A用户在修改完之后并将file.txt提交到服务器,这个时候A的提交是成功...

解析oracle对select加锁的方法以及锁的查询

解析oracle对select加锁的方法以及锁的查询 一、oracle对select加锁方法 create table test(a number,b number); insert i...

ObjC 线程同步加锁[转]

Objective-C对线程同步和异常处理提供支持,关于异常处理,请参考“Exception Handling.” 你可以使用编译标记-fobjc-exceptions来打开对异常的支持,不过必须是在...

文件创建、文件加锁等总结

// 在路径d:/test下创建文件liujg File file = new File("d:/test/liujg"); if (file.getParentFile().isFile())...

对测试IDServer加锁性能后,收到建议反馈后的思考总结

作为公司的新人小菜鸟,在对《IDServer性能以及加锁的影响》进行测试,并抛出发现的问题后,收到了很多大牛的热情反馈和宝贵建议,有些建议真是一针见血,直接指出了测试中的一些缺陷,有些建议很好地指出了...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)