1 什么是AQS?
AQS是AbstractQueuedSynchronizer的简称.哦,你知道了它是一个类,这个类是干嘛用的,它的数据结构是什么样的?为什么它是并发编程 的核心思想呢?说到并发编程你可能会想到可见性,原子性,禁止指令重排。那么你可能会猜想这个思想 可能会跟可见性,原子性有着一定的关系。ok,我们带着这个猜想去看源码;
private transient volatile Node head;
private transient volatile Node tail;
private volatile int state;//作为CAS操作的一个标志,0代表没有加锁;1代表加锁;
Node{
volatile Node prev;
volatile Node next;
volatile Thread thread;
}
ok,我们看完源码感觉好多,最重要的就是这几项;我们可以把AQS理解成一个双向链表;但是链表的值是每一个线程;就好比火车站排队买票,AQS就是很长的一个队伍;head就是第一个人;tail是最后一个人;而他们前后都有人;每一个thread就是他们要干的什么 事儿,或者可以说办什么业务,只有等前面一个人的事儿办完了下面一个人才可以被受理;
这个思想博大精深呀,比如我们熟悉的ReentrentLock;假如第一个人它办完了一件事儿之后;他又要买另外的车票;这样不就相当于重入了吗?具体的我会在ReentrentLock源码分析中具体分析。
https://www.jianshu.com/p/da9d051dcc3d