对AbstractQueuedSychronizer的粗略理解

AbstractQueuedSychronizer理解

从ReentrantLock入手了解,其提供了两种锁,一种是公平锁,一种是非公平锁;

这两种锁都继承了抽象类Sync extends AbstractQueuedSychronizer,里面有一个抽象方法和两个主要函数


一、非公平锁NonfairSync

它是继承了Sync

对于公平锁,例如线程1通过lock()获取锁,这时候



通过CAS操作compareAndSetState(0,1)判断,如果state0,则没有任何线程获取该锁,所以置为1setExclusiveOwnerThread(Thread.currentThread());设置独占锁的拥有者为当前线程。因为这时候只有线程1,所以acquire(1)等会再说。

加入现在线程1正在占有着锁,这时候线程2也调用lock()获取锁,这时候CAS操作失败,进入acquire(1)函数


这时候tryAcquire(1)其实就是调用NonfairSync里面重写的函数,


然后来看nonfairTryAcquire这个函数


接下来是acquireQueued(addWaiter(Node.EXCLUSIVE),arg),其中addWaiter(Node.EXCLUSIVE)是添加一个等待节点到队列当中,Node.EXCLUSIVE说明添加的是一个独占锁类型的节点


添加完节点之后就会acquireQueued()通过队列中获取锁



以下就是将当前线程挂起,等待中断唤醒





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值