公平锁指线程按请求顺序获取锁,先到先得,避免饥饿。ReentrantLock默认非公平,构造时传true可启用公平模式,如new ReentrantLock(true),确保等待最久的线程优先获得锁。

在Java中,ReentrantLock 可以用来实现公平锁。默认情况下,ReentrantLock是非公平的,但可以通过构造函数参数设置为公平模式。
公平锁是指线程获取锁的顺序严格按照它们请求锁的时间顺序,即先等待的线程优先获得锁(FIFO)。这避免了线程“饥饿”问题,但可能降低吞吐量,因为需要维护排队机制。
创建 ReentrantLock 时,传入 true 参数即可启用公平策略:
示例代码:
立即学习“Java免费学习笔记(深入)”;
import java.util.concurrent.locks.ReentrantLock;
public class FairLockExample {
// true 表示使用公平锁
private final ReentrantLock lock = new ReentrantLock(true);
public void performTask() {
lock.lock();
try {
System.out.println(Thread.currentThread().getName() + " 获取了锁");
// 模拟工作
Thread.sleep(100);
} catch (InterruptedException e) {
Thread.currentThread().interrupt();
} finally {
lock.unlock();
}
}
public static void main(String[] args) {
FairLockExample example = new FairLockExample();
Runnable task = example::performTask;
// 启动多个线程竞争锁
for (int i = 1; i <= 5; i++) {
new Thread(task, "Thread-" + i).start();
}
}
}
虽然公平锁更“公正”,但有以下几点需要注意:
基本上就这些。如果你的应用场景对线程等待时间敏感,比如希望避免个别线程长期得不到执行,可以考虑使用公平锁。否则,默认的非公平锁在大多数情况下表现更好。
以上就是Java中如何使用Lock实现公平锁的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号