【Java】 Java AQS 分析

Java AQS是Java中提供的一个用于实现同步控制的工具。AQS全称为AbstractQueuedSynchronizer,是JDK1.5后新增的一个同步化工具类,常用于实现锁、信号量等同步控制。

AQS的核心思想是使用一个FIFO队列来管理等待线程的状态,并使用一些原子操作来控制队列中线程的状态转换。基于这个队列,AQS提供了两种同步实现方式:排他锁(ReentrantLock)和共享锁(ReentrantReadWriteLock)。

具体来说,AQS提供了抽象类AbstractOwnableSynchronizer,该类中定义了一个volatile变量state用于记录当前同步状态并提供了一些基本的操作,例如get/set/compareAndSet等。在AQS的具体实现中,可以通过继承AbstractOwnableSynchronizer来实现自定义的同步器。

AQS另外一个关键的类是Node,它是一个FIFO队列中的一个节点,用于记录等待线程的状态,并维护一个双向链表的结构。当一个线程需要获取同步器的锁时,会创建一个Node,并将其加入到等待队列中,等待锁的释放。而锁释放后,AQS会从等待队列中选取一个线程来获取锁,并标记自己已经获取了锁,此时其他等待线程将继续等待。

AQS的具体实现中,定义了两条队列:一个用于记录等待获取锁的线程,另一个用于记录已经获取锁的线程。等待队列中的节点存在两种状态:独占和共享。独占节点只能被一个线程获取锁,而共享节点可以被多个线程同时获取锁。在获取锁的过程中,会先尝试获取独占节点,如果独占节点已经被其他线程获取,则获取共享节点,如果共享节点也被占用,则加入等待队列继续等待。

AQS的实现原理虽然复杂,但是它提供了简单可靠的同步控制,为Java中的多线程编程带来了便利。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值