ReentrantLock源码lock和tryLock区别

ReentrantLock的lock方法包含尝试加锁和排队功能,若加锁失败会进入等待队列。而tryLock仅尝试加锁,成功返回true,失败返回false,不涉及排队机制。
摘要由CSDN通过智能技术生成

在reentrantLock中,提供了一个lock和一个tryLock方法,这两个方法是有区别的,这篇笔记主要记录下具体的区别信息

结论

其实对于这个两个方法,简单来说,tryLock()方法,返回的是一个boolean类型变量,返回true,表示加锁成功,返回false,表示加锁失败,但是这个方法是没有排队的功能的
lock()方法有两个功能:尝试加锁 + 排队;所以,lock方法如果加锁失败,会去排队,我们也可以简单的认为,lock = tryLock + 排队方法

lock()源码

lock在加锁的时候,我们看下源码,以非公平锁为例

/**
 * 非公平锁在加锁的时候,会先尝试加锁,如果加锁失败,就调用acquire();
 * 在acquire()方法中,公平锁和非公平锁的区别是:在state为1的时候,非公平锁不会判断当前是否允许加锁,而是直接cas加锁,如果加锁失败,就去排队,后面的流程,就和公平锁一样了
 */
final void lock() {
	if (compareAndSetState(0, 1))
		setExclusiveOwnerThread(Thread.currentThread());
	else
		acquire(1);
}


public final void acquire(int arg) {
	if (!tryAcquire(arg) &&
		acquireQueued(addWaiter(Node.EXCLUSIVE), arg))
		selfInterrupt();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值