当前位置: 首页 > news >正文

java中ReentrantLock的实现原理是什么?

ReentrantLock 的实现原理主要涉及到两个关键概念:同步器(Sync)和 AQS(AbstractQueuedSynchronizer,抽象队列同步器)。

ReentrantLock 使用 AQS 来实现可重入锁的机制。AQS 是 Java 并发包中的一个抽象基类,为实现锁和其他同步器提供了一种统一的框架。ReentrantLock 则是基于 AQS 提供的框架实现的。

以下是 ReentrantLock 的主要实现原理:

1. AQS 的状态:

AQS 内部维护一个状态变量,用来表示被保护资源的状态。对于 ReentrantLock 来说,状态值表示当前锁被持有的次数。当状态为0时表示锁未被持有,大于0时表示锁已被某个线程持有。

2. 同步器(Sync)的实现:

ReentrantLock 的内部实现继承了 AQS,并提供了两个具体的实现类:NonfairSyncFairSync,分别对应非公平锁和公平锁。

  • NonfairSync:在尝试获取锁时,不考虑其他线程是否在等待队列中等待锁,直接尝试获取。
  • FairSync:在尝试获取锁时,会优先考虑等待时间最长的线程,以实现公平性。

3. AQS 的队列:

AQS 使用一个双向链表作为等待队列,将请求锁但未能成功获取的线程加入队列。队列中的节点代表等待线程。

4. 获取锁的流程:

  • 当一个线程尝试获取锁时,如果锁的状态为0,则表示锁未被持有,线程可以直接获取锁,并将状态设置为1。
  • 如果锁的状态不为0,表示锁已经被其他线程持有,此时线程将被加入等待队列,并被挂起,直到锁被释放。
  • 当持有锁的线程再次尝试获取锁时,AQS 会判断当前线程是否已经持有锁。如果是,直接增加状态值;如果不是,则将该线程加入等待队列。

5. 释放锁的流程:

  • 当一个线程释放锁时,AQS 会将状态值减1。
  • 如果状态值为0,表示锁已经完全释放,此时会唤醒等待队列中的下一个线程。
  • 如果状态值不为0,表示锁仍然被持有,此时直接减少状态值。

6. 实现可重入性:

ReentrantLock 的实现允许同一个线程多次获取锁,这是通过在节点中维护一个记录线程持有次数的变量来实现的。线程持有锁时,增加该变量;释放锁时,减少该变量。只有当该变量减到0时,才表示锁完全被释放。

ReentrantLock 通过 AQS 提供的队列和状态管理机制,实现了可重入锁的机制,保证了锁的正确性和灵活性。不同的实现类(NonfairSyncFairSync`)在获取锁的策略上有所区别,分别支持非公平锁和公平锁。

http://www.lryc.cn/news/255611.html

相关文章:

  • C语言精选——选择题Day40
  • 大屏适配方案一scale()
  • WordPress免费插件大全清单【2023最新】
  • 支付宝小程序接口传参会默认排序
  • Numpy数组的运算(第7讲)
  • node后端接口无法插入数据为emoji的表情的问题
  • Conda常用命令总结
  • Oracle数据库如何实现自增-序列Sequence介绍(适合小白)
  • ke14--10章-2JDBC例子
  • 04数据平台Flume
  • Redis--13--缓存一致性问题
  • 12.7作业
  • ssl什么是公钥和私钥?
  • github首次将文件合到远端分支,发现名字不是master,而是main
  • RTX 40 系彻底摆烂,NVIDIA 让三年老卡焕发第二春
  • ELK技术栈介绍及简单使用实例
  • 基于Java健身房课程管理系统
  • DAPP开发【02】Remix使用
  • 大华DSS S2-045 OGNL表达式注入漏洞复现
  • 大数据之HBase(二)
  • 前后端数据传输格式(下)
  • mysql pxc高可用离线部署(三)
  • XXL-JOB 日志表和日志文件自动清理
  • 常用sql记录
  • 设备温度和振动综合监测:温振一体式传感器的优点和应用
  • 彻底解决ModuleNotFoundError: No module named ‘exceptions‘【Bug完美解决】
  • yarn和npm的区别
  • 设计图中时序图
  • 反射实现tomcat
  • Ubuntu 安装 CUDA 和 cuDNN 详细步骤