多线程-锁-ReentrantLock

本文详细解析了ReentrantLock的工作原理,包括其基于CAS机制的竞争同一标志位来实现锁的过程,以及内部实现的公平锁和非公平锁的区别。介绍了如何通过标志位的加减操作实现线程的重入和锁的释放。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

多线程-锁-ReentrantLock

ReentrantLock,通过CAS机制,所有线程竞争同一ReentrantLock对象内部的volatile int 类型标志位,实现锁。

volatile int标志位初始为0,。当有线程lock()时,如果标志位此时为0,标志位通过CAS机制加一,如果成功加一,ReentrantLock对象将持有该线程引用。在该线程释放锁之前,该线程可以多次调用lock()重入共享资源,此时标志位每次都会加一,在完全释放锁时要将标志位释放至0。

ReentrantLock 内部实现了公平锁和非公平锁。

非公平锁:所有线程竞争共享资源,所有线程处于同等优先级,不会因为某个线程先创建而拥有较高的优先级。这对于先创建的线程而言,是不公平的。

公平锁:内部通过维护一个等待线程的链表,实现对线程加入顺序的维护,在竞争锁时,会检查链表中是否有等待时间更久的线程,如果有,则当前获得锁的线程不占有锁。所有线程重新开始竞争锁,直到等待时间最久的线程获得锁。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值