Java基础 -> 谈谈你对AQS的理解,AQS如何实现可重⼊锁?

本文深入解析了AQS中的核心概念,包括state、加锁线程变量和双向链表队列在实现可重入锁中的作用。重点介绍了乐观锁、悲观锁的转换过程,以及state变量如何计数加解锁。理解AQS有助于掌握Java并发控制的基础。
摘要由CSDN通过智能技术生成

谈谈你对AQS的理解,AQS如何实现可重⼊锁?

  • AQS是⼀个JAVA线程同步的核心组件。是JDK中很多锁⼯具的核心组件

  • AQS的锁是先尝试CAS乐观锁去获取锁,获取不到,才会转换为悲观锁

  • 在AQS中,维护了⼀个信号量state加锁线程变量和⼀个线程组成的双向链表队列

    • 其中,这个线程队列,就是⽤来给线程排队的
    • 加锁线程变量就是当前加锁的线程
    • ⽽state就像是⼀个红绿灯,⽤来控制线程排队或者放⾏的。
      • 这个加锁的过程,直接就是用CAS操作将state值从0变为1。
      • 预计为0,修改+1
  • 如果是同一个线程,多次加锁state就会叠加,不会出现死锁

  • 在可重⼊锁这个场景下,state就⽤来表示加锁的次数。

    • 0标识⽆锁,每加⼀次锁,state就加1。释放锁state就减1。

state变量在AQS类中private volatile int state;

双向链表队列变量在AQS类中private transient volatile Node head;

加锁线程变量在**AOS**类中private transient Thread exclusiveOwnerThread;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值