什么是CAS, 什么是AQS

文章目录

  • [什么是CAS, 什么是AQS](#什么是CAS, 什么是AQS)

什么是CAS, 什么是AQS

CAS


AQS

AQS 全称是AbstractQueuedSynchronizer, 是juc 下一个核心的抽象类,用于构建各种同步器和锁

比如我们熟悉的 ReentrantLock、ReadWriteLock、CountDownLatch等等是基于AQS.

首先在AQS 里面,有几个核心的组成

● 有volatile 修饰的 state 变量: 共享资源的状态

● 以Node节点组成的双端队列------CLH 也是由volatile进行修饰

● 两个维护队列的Node节点head 和 tail

AQS 基本的属性------源码

java 复制代码
public abstract class AbstractQueuedSynchronizer
    extends AbstractOwnableSynchronizer
    implements java.io.Serializable {
    //头节点
    private transient volatile Node head;
    //尾节点
    private transient volatile Node tail;
    //同步状态
    private volatile int state;   
     static final class Node {
            //节点状态
            volatile int waitStatus;
            //前驱节点
            volatile Node prev;
            //后继节点
            volatile Node next;
            //当前节点所代表的线程
            volatile Thread thread;
            //等待队列使用时的后继节点指针
            Node nextWaiter;
    }
}    
相关推荐
未若君雅裁4 分钟前
死锁产生条件与诊断:jps、jstack、VisualVM
java·开发语言
再玩一会儿看代码4 分钟前
Java抽象类和接口区别_场景理解
java·开发语言·经验分享·笔记·python
用户925807911485 分钟前
画图理解mysql日志机制
java·后端
javahongxi8 分钟前
Spring Cloud Trace 链路实现
java·spring boot·spring cloud
海梨花10 分钟前
腾讯面试高频算法题
java·算法·面试
于先生吖11 分钟前
Java消息队列优化抢单逻辑,同城搬家拉货多场景业务数据库架构设计
java·开发语言·数据库架构
小谢小哥12 分钟前
68-持续集成详解
java·后端·架构
用户9258079114813 分钟前
redission原理
java·后端
小旭952713 分钟前
Spring Cloud 集成分布式日志 ELK+Swagger 接口文档实战
java·分布式·后端·elk·spring cloud