AQS中Node状态

在AQS(AbstractQueuedSynchronizer)中,Node 是一个用于构建等待队列的节点类,用于表示等待获取锁的线程。Node 的状态在不同的同步器中有不同的含义,但一般来说,Node 的状态可以分为以下几种:

  1. CANCELLED (值为1):

    表示节点已被取消。当一个线程等待获取锁的过程中被中断或超时,节点的状态可能被设置为 CANCELLED。

  2. SIGNAL (值为-1):

    表示后继节点需要被唤醒。当一个节点释放锁的时候,会唤醒它的后继节点,SIGNAL 就用于表示这个需要唤醒的状态。

  3. CONDITION (值为-2):

    表示节点在等待条件队列中。当一个线程在等待条件变量时,会被放入条件队列,节点的状态被设置为 CONDITION。

  4. PROPAGATE (值为-3):

    用于共享模式。表示 releaseShared 应该传播。在共享模式下,可能需要通过 PROPAGATE 来通知其他线程继续获取共享资源。

  5. 0:

    表示初始状态或无特殊状态。在等待队列中的节点,如果还没有进入到同步队列中等待获取锁,其状态为初始状态。

在AQS的源码中,这些状态常常通过 Node 类的常量来表示,例如:

java 复制代码
static final int CANCELLED =  1;
static final int SIGNAL    = -1;
static final int CONDITION = -2;
static final int PROPAGATE = -3;

这些状态的具体含义和使用取决于具体的同步器实现,因为不同的同步器可能有不同的语义和处理逻辑。在实际使用AQS时,通常不需要直接操作 Node 的状态,而是通过同步器提供的方法来实现线程的同步和协作。

相关推荐
while(1){yan}8 分钟前
网络编程UDP
java·开发语言·网络·网络协议·青少年编程·udp·电脑常识
大猫子的技术日记9 分钟前
【工具篇】极简入门 UV Python项目管理工具
开发语言·python·uv
古城小栈12 分钟前
边缘计算:K3s 轻量级 K8s 部署实践
java·kubernetes·边缘计算
武子康12 分钟前
Java-196 消息队列选型:RabbitMQ vs RocketMQ vs Kafka
java·分布式·kafka·rabbitmq·rocketmq·java-rocketmq·java-rabbitmq
小年糕是糕手13 分钟前
【C++同步练习】类和对象(三)
开发语言·jvm·c++·程序人生·考研·算法·改行学it
m0_7400437316 分钟前
SpringBoot02-SpringMVC入门
java·开发语言·spring boot·spring·mvc
wadesir17 分钟前
Judy数组:C语言中的高性能动态数组(全面入门Judy库使用指南)
c语言·开发语言
csbysj202017 分钟前
SQLite Glob 子句详解
开发语言
Seven9718 分钟前
字符串匹配算法
java
ss27319 分钟前
阻塞队列:生产者-消费者模式
java·开发语言