如果没有这次读源码的经历,我可能一直会带着错误的思想
不想说长篇大论用最简洁明了的两张图看出实际的对比,本次追源码用的是reentrantlock,用它的公平和非公平锁的对比,折射出其中的原理。
前面怎么追的,大家自己体会一下 我直接放精髓 (上下对比)

![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-4vL1EYVs-1667114250666)(/upload/2022/06/image-66b2758854834f81a9a9b2dc765e5acb.png)]](https://i-blog.csdnimg.cn/blog_migrate/930d979781129be0bb2eace73664ccbd.png)
上面第一张图是公平锁的lock,下面的是非公平锁,这两张图其实也是看不出实际区别,区别就是,非公平会尝试先去获得一次锁,重点在acquire,我们追进去看看。

acquire里面都是相同的,我们看tryAcquire


这下就够明显的了,前者会根据等待队列中是否有等待的节点判断是否获取,而后者不会,这就是公平和非公平最本质的区别。
这次的博文很简短,但我认为能带来的确实很多,至少解决了我前段时间的一种囫囵吞枣的感觉,一起继续加油吧!
1938

被折叠的 条评论
为什么被折叠?



