一、公平锁1、为什么有公平锁 CPU在调度线程的时候是在等待队列里随机挑选一个线程,由于这种随机性所以是无法保证线程先到先得的(synchronized控制的锁就是这种非公平锁)。但这样就会产生饥饿现象,即有些线程(优先级较低的线程)可能永远也无法获取cpu的执行权。那么如何解 ...
一、公平锁
1、为什么有公平锁
CPU在调度线程的时候是在等待队列里随机挑选一个线程,由于这种随机性所以是无法保证线程先到先得的(synchronized控制的锁就是这种非公平锁)。但这样就会产生饥饿现象,即有些线程(优先级较低的线程)可能永远也无法获取cpu的执行权。那么如何解决饥饿问题呢,这就需要公平锁了。
2、什么是公平锁
公平锁可以保证线程按照时间的先后顺序执行,避免饥饿现象的产生。但公平锁的效率比较地,因为要实现顺序执行,需要维护一个有序队列。
二、公平锁的使用
JDK1.5为我们提供了实习公平锁的方式,创建公平锁的构造函数是:
java.util.concurrent.locks.ReentrantLock
public ReentrantLock(boolean fair) { sync = fair ? new FairSync() : new NonfairSync(); }
海外公司注册、海外银行开户、跨境平台代入驻、VAT、EPR等知识和在线办理:https://www.xlkjsw.com
原标题:java线程 公平锁 ReentrantLock(boolean fair)
关键词:JAVA
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:
admin#shaoqun.com
(#换成@)。