浅析AQS
#前言 好久没写blog了,最近学车,时间真的少了很多,花了一些时间写了一篇AQS,请大家指正。 概述 翻阅AbstractQueuedSynchronizer的源码,会发现如下注释: Pprovides a framework for implementing blocking locks and related synchronizers (semaphores, events, etc) that rely on first-in-first-out (FIFO) wait queues. AbstractQueuedSynchronizer提供一个基于FIFO队列的框架,该框架用于实现阻塞锁和相关同步器(例如:semaphores)。 如此可知,AbstractQueuedSynchronizer可以视为JDK同步器的框架,理解它,有助于理解JDK的同步器。 框架说明 本人依据JDK源码中的注释结合并发经验,总结了如下AQS框架说明: AQS是依赖状态进行同步操作的,其内部使用一个整形变量state,来表示同步状态,此状态值依据具体的同步器语义实现。例如:在CountDownLatch中state即为需要等待的线程数。 AQS的子类必须定义在获取和释放上对应的状态值。对于AQS状态变量的操作必须使用getState,setState,compareAndSetState