公平锁与非公平锁相同点
底层都是通过AQS进行排队实现的,不管是公平锁还是非公平锁,一旦没有竞争到锁,都会进行排队,当锁释放时,都是唤醒排在最前面的线程。
公平锁与非公平锁不同点
线程使用 lock() 方法加锁时
如果是公平锁,会先检查 AQS队列中是否存在线程排队,如果有线程在排队,那么当前线程也进行排队;
如果是非公平锁,则不会去检查 AQS队列中是否有线程排队,而是直接去竞争锁;
因此非公平锁与公平锁只是体现在加锁阶段,而没有体现在唤醒阶段;另外 Reentrantlock 是可重入锁,不管公平锁还是非公平锁;
注意:重入几次锁,后面也得释放几次锁;
如下:
ReentrantLock lock = new ReentrantLock();
lock.lock();
lock.lock();
lock.unlock();
lock.unlock();
网友回复
如何修改别人发给我的微信笔记内容?
fbx、obj、glb三维格式模型如何在浏览器中通过three相互转换格式?
python如何实现基于http隧道加密的正向代理服务?
有没有有专门针对 UI 界面截图进行智能标记(Set-of-Mark, SoM) 的开源库和工具?
如何用python实现Set-of-Mark (SoM) 技术?
python如何截取windows指定应用的窗口截图,不用管窗口是不是在最前面?
linux能不能给rm删除命令增加回收站功能,可恢复被删文件?
bfwsoa如何在命令行中执行控制器动作器方法?
RAG(检索增强生成)和 KG(知识图谱)有啥不同?
KVM硬件是啥?


