ReentrantLock
时间: 2023-10-03 12:08:41 浏览: 107
ReentrantLock是Java中的一个锁实现类。它具有可重入性,即同一个线程在持有锁的情况下可以再次获取该锁,这意味着线程可以多次进入被锁保护的代码块。 可以通过ReentrantLock的构造函数来指定锁的公平性,默认情况下是非公平锁,可以通过设置参数为true来创建一个公平锁。需要注意的是,公平锁会降低并发度,所以在大多数情况下,使用非公平锁是更好的选择。 ReentrantLock还支持条件变量的使用,可以通过ReentrantLock的newCondition方法创建一个条件变量,用于线程间的通信与同步。
ReentrantLock的可重入性是通过AQS(AbstractQueuedSynchronizer)实现的。无论是公平锁还是非公平锁,都会在内部维护一个同步状态变量,用于判断锁是否被当前线程持有。在获取锁的过程中,会判断当前线程是否已经持有了锁,如果是,则直接返回;如果不是,则会进入AQS的acquire方法进行等待获取锁的过程。 通过这种方式,ReentrantLock实现了可重入性,使得同一个线程在持有锁的情况下可以再次获取锁。
总之,ReentrantLock是一个支持可重入性、可打断和条件变量使用的锁实现类,它在多线程环境下提供了更高级别的同步控制。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* [ReentrantLock的基本使用&常用方法](https://blog.csdn.net/m0_63463465/article/details/128265983)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
- *3* [ReentrantLock 锁详解](https://blog.csdn.net/zhengzhaoyang122/article/details/110847701)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文