如果没有这次读源码的经历,我可能一直会带着错误的思想
不想说长篇大论用最简洁明了的两张图看出实际的对比,本次追源码用的是reentrantlock,用它的公平和非公平锁的对比,折射出其中的原理。
前面怎么追的,大家自己体会一下 我直接放精髓 (上下对比)
上面第一张图是公平锁的lock,下面的是非公平锁,这两张图其实也是看不出实际区别,区别就是,非公平会尝试先去获得一次锁,重点在acquire,我们追进去看看。
acquire里面都是相同的,我们看tryAcquire
这下就够明显的了,前者会根据等待队列中是否有等待的节点判断是否获取,而后者不会,这就是公平和非公平最本质的区别。
这次的博文很简短,但我认为能带来的确实很多,至少解决了我前段时间的一种囫囵吞枣的感觉,一起继续加油吧!