侧边栏壁纸
博主头像
Monkey部落博主等级

Monkey部落,分享技术、经验、遇到的问题及解决方法,欢迎大家互相讨论分享。

  • 累计撰写 59 篇文章
  • 累计创建 36 个标签
  • 累计收到 2 条评论

目 录CONTENT

文章目录

ReentrantLock中的公平锁和非公平锁的底层实现

Monkey部落
2024-04-08 / 0 评论 / 0 点赞 / 22 阅读 / 261 字
温馨提示:
本文最后更新于 2024-04-08,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

ReentrantLock中的公平锁和非公平锁的底层实现

首先不管是公平锁还是非公平锁,它们的底层实现都会使用AQS来进行排队,它们的区别在于:线程在使用lock()方法加锁时,如果是非公平锁,会先检查AQS队列中是否存在线程在排队,如果有线程在排队,则当前线程也进行排队,如果是非公平锁,则不去检查是否有线程在排队,而是直接竞争锁。

不管是公平锁还是非公平锁,一旦没竞争到锁,都会进行排队,当锁释放时,都是唤醒排在最前面的线程,所以非公平锁只是体现在线程加锁阶段,而没有体现在线程被唤醒阶段。

另外,ReentrantLock时可重入锁,不管是公平锁还是非公平锁都是可重入锁。默认是非公平锁。

0

评论区