Reentrantlock简介及使用场景
转自:
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()方法提供了可中断锁来解决此问题