博客
关于我
ReentrantLock的公平锁与非公平锁
阅读量:794 次
发布时间:2023-02-27

本文共 1495 字,大约阅读时间需要 4 分钟。

ReentrantLock类是Java中一个高级同步工具,它通过内部的FairLock和NonfairLock两个子类实现了公平锁和非公平锁的功能。这两个子类都继承自Sync类,通过FIFO队列实现线程的等待和调度。

NonfairLock的独特之处

NonfairLock的实现与FairLock的主要区别在于它在获取锁时的逻辑判断。NonfairLock在尝试获取锁时不会检查队列头部是否有等待的线程,而是直接根据当前状态进行判断。

boolean nonfairTryAcquire(int acquires) {
Thread current = Thread.currentThread();
int c = getState();
if (c == 0) {
if (compareAndSetState(0, acquires)) {
setExclusiveOwnerThread(current);
return true;
}
} else if (current == getExclusiveOwnerThread()) {
int nextc = c + acquires;
if (nextc < 0) {
throw new Error("Maximum lock count exceeded");
}
setState(nextc);
return true;
}
return false;
}

FairLock的实现逻辑

FairLock则在获取锁时会检查队列中是否有等待的线程。它通过hasQueuedPredecessors()方法来判断当前线程是否是队列中的后续线程。

boolean tryAcquire(int acquires) {
Thread current = Thread.currentThread();
int c = getState();
if (c == 0) {
if (!hasQueuedPredecessors() && compareAndSetState(0, acquires)) {
setExclusiveOwnerThread(current);
return true;
}
} else if (current == getExclusiveOwnerThread()) {
int nextc = c + acquires;
if (nextc < 0) {
throw new Error("Maximum lock count exceeded");
}
setState(nextc);
return true;
}
return false;
}

关键实现细节

在这两种锁的实现中,最关键的区别在于NonfairLock是否检查队列中的线程。NonfairLock直接尝试获取锁,而FairLock则会先检查是否有其他线程在等待。如果有,FairLock会确保只有当前线程才能获取锁,避免其他线程在不公平的情况下获得优先权。

转载地址:http://eevfk.baihongyu.com/

你可能感兴趣的文章
pandas读取parquet报错
查看>>
pandas读取数据用来深度学习
查看>>
Pandas进阶大神!从0到100你只差这篇文章!
查看>>
spring5-介绍Spring框架
查看>>
pandas,python - 如何在时间序列中选择特定时间
查看>>
Spring 框架之 AOP 原理深度剖析
查看>>
Pandas:如何按列元素的组合分组,以指示基于不同列的值的同现?
查看>>
Pandas:将一列与数据帧的所有其他列进行比较
查看>>
PANDA:基于多列对数据表的行运行计算,并将输出存储在新列中
查看>>
PandoraFMS 监控软件 SQL注入漏洞复现
查看>>
PandoraFMS 监控软件 任意文件上传漏洞复现
查看>>
Papyrus项目常见问题解决方案
查看>>
Parallel.ForEach使用示例
查看>>
Parallel.ForEach的基础使用
查看>>
parallels desktop for mac安装虚拟机 之parallelsdesktop密钥 以及 parallels desktop安装win10的办公推荐可以提高办公效率...
查看>>
parallelStream导致LinkedList遍历时空指针的问题
查看>>
Parameter ‘password‘ not found. Available parameters are [md5String, param1, username, param2]
查看>>
ParameterizedThreadStart task
查看>>
Spring security之管理session
查看>>
paramiko模块
查看>>