转自:
http://www.java265.com/JavaCourse/202205/3299.html
下文笔者讲述Reentrantlock的相关简介说明及其使用场景,如下所示:
Reentrantlock简介
- 1.Reentrantlock是并发包中一个可重入的锁
- 是基于AQS(AbstractQueuedSynchronized)实现
- 它有公平锁和不公平锁两种实现方式
-
- 2.Reentranlock中有一个内部抽象类Sync继承自AbstractQueuedSynchronized
- 主要是它来实现锁的功能
- Sync在ReentrantLock中有两种实现类
- NonfairSync、FairSync
- 正好对应了ReentrantLock的非公平锁、公平锁两大类型
- Reentranlock 默认实现为非公平锁
- 在高竞争的条件下有更好的性能
复制代码 ReentrantLock的使用场景
- 1.检测有操作在运行,则不运行指定代码块(可避免并发竞争)
- 如:在定时任务时,当任务执行时间可能超过下次计划执行时间,确保该任务只有一个正在执行,忽略重复触发。
- 2.当该操作已经在执行,则等待一个个执行(同步执行,与synchronized相似)
- 3.当该操作已经在执行,则尝试等待一段时间,超时则放弃执行
- 等待获得锁的操作有一个时间的限制
- 如果超时则放弃执行,用来防止由于资源处理不当长时间占用导致死锁情况
- 4.当发现该操作已经在执行,等待执行,此时可中断正在进行的操作立刻释放锁继续下一操作
- synchronized与Lock在默认情况下是不会响应中断(interrupt)操作
- 会继续执行完
- Reentranlock中的lockInterruptibly()方法提供了可中断锁来解决此问题
复制代码 免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |