通过对AQS及相关类的源码分析,我得到以下总结。
AQS 的底层原理
AQS是一个同步框架,内部实现了一个同步队列,在acquire/shared和release/shared方法中,经tryRelease和tryAcquire判断,对调用线程进行了入队挂起或激活抢锁操作。而判断的细节tryRelease和tryAcquire交由子类实现,以适应不同场景的需要。基于此可以实现各种各样的锁及相关工具。
对于 CountDownLatch 和 CyclicBarrier,semaphore的认识
countDownLatch和semaphore 通过内部类继承于AQS,实现了tryAcquireshare和tryReleaseShare方法,通过控制state字段值,进行线程的入队和出队操作。countDown 的countdown方法将state进行单向减,到0时激活同步队列中await线程。semaphore,可以通过acquire和release对state值进行增减,acquire时如果state等于0等入队,当release时激活同步队列进行出队。
cyclicBarrier并没有使用内部类继承AQS,而是使用ReentrantLock和condition进行资源的锁定和释放。
countDownLatch 是递减一次性的,用于主线程等待子线程。
cyclicBarrier 可以循环使用,用于多个线程相互等待。
semaphore 可以增减,用于维持最多n的线程同时进行,类似于令牌桶。
欢迎探讨。