关于ReentrantLock的lock()方法的一个疑问

Jisfeng 2018-03-17 06:21:06
ReentrantLock里,公平锁和非公平锁在尝试获取锁失败,!tryAcquire(arg)为true后,会调用acquireQueued(addWaiter(Node.EXCLUSIVE), arg)方法,方法源码如下:



为什么这里p==head的时候才会再次尝试获取锁?对于非公平锁,竞争锁不是不依赖排队顺序?不是应该不管前驱结点是否是head,都应该再次去尝试获取锁吗?
...全文
304 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧