公平锁与非公平锁相同点
底层都是通过AQS进行排队实现的,不管是公平锁还是非公平锁,一旦没有竞争到锁,都会进行排队,当锁释放时,都是唤醒排在最前面的线程。
公平锁与非公平锁不同点
线程使用 lock() 方法加锁时
如果是公平锁,会先检查 AQS队列中是否存在线程排队,如果有线程在排队,那么当前线程也进行排队;
如果是非公平锁,则不会去检查 AQS队列中是否有线程排队,而是直接去竞争锁;
因此非公平锁与公平锁只是体现在加锁阶段,而没有体现在唤醒阶段;另外 Reentrantlock 是可重入锁,不管公平锁还是非公平锁;
注意:重入几次锁,后面也得释放几次锁;
如下:
ReentrantLock lock = new ReentrantLock();
lock.lock();
lock.lock();
lock.unlock();
lock.unlock();
网友回复
如何编写一个chrome插件实现多线程高速下载大文件?
cdn版本的vue在网页中出现typeerror错误无法找到错误代码位置怎么办?
pywebview能否使用webrtc远程控制共享桌面和摄像头?
pywebview6.0如何让窗体接受拖拽文件获取真实的文件路径?
如何在linux系统中同时能安装运行apk的安卓应用?
python有没有离线验证码识别ocr库?
各家的ai图生视频及文生视频的api价格谁最便宜?
openai、gemini、qwen3-vl、Doubao-Seed-1.6在ui截图视觉定位这款哪家更强更准?
如何在linux上创建一个沙箱隔离的目录让python使用?
pywebview如何使用浏览器自带语音识别与webspeech 的api?