码迷,mamicode.com
首页 > 其他好文 > 详细

显式锁

时间:2018-12-11 16:04:44      阅读:195      评论:0      收藏:0      [点我收藏+]

标签:互斥   另一个   lock   情况下   dwr   并发   多个   处理   情况   

1 ReentrantLock 实现了 Lock 接口,并提供了与 synchronized 相同的互斥性和内存可见性。还提供了可重入的加锁寓意。

内置锁中,死锁是一个严重的问题,主要原因是多个获取锁的顺序形成了一个环,恢复程序的唯一方法是重启程序,而防止死锁的唯一方法就是在构造程序时避免出现不一致的锁顺序。

可定时的或可轮训的锁提供了另外的解决方法。

 

2 锁的公平性:是否按照请求顺序来获得锁。

对于锁竞争比较激烈、每个线程获得锁后处理时间比较短的话使用非公平的锁比较好。因为要唤醒因获取该锁而挂起的线程并不是即时的,需要回复上下文等一系列操作,如果此时另一个线程来获取该锁,并一会就结束,那么非公平锁会有更高的效率。

对于获取锁不激烈,即每个获取锁的间隔比较长,而持有所的时间相对较长,此时使用公平锁更好。

 

3 ReentrantLock 与 synchronized 比较

在大多数情况下使用 synchronized 比较好,只有 synchronized 不能满足需要时使用 ReentrantLock

ReentrantLock 优点

  • 可以是等待可中断的锁:持有锁线程长时间持有锁,等待线程在规定时间外放弃获得锁。
  • 公平锁:ReentrentLock 可以实现公平锁
  • 绑定多个条件:ReentrantLock 可以实现绑定多个条件的锁。

 

4 ReadWriteLock

当读取操作远多于写入操作时,使用读写锁可以提高并发性。

 

显式锁

标签:互斥   另一个   lock   情况下   dwr   并发   多个   处理   情况   

原文地址:https://www.cnblogs.com/zhaopengcheng/p/10102159.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!