说说 CountDownLatch 原理
CountDownLatch使用讲解
《java变成思想》(第四版英文版) P1230
总结:
CountDownLatch 内部维护了一个整数n,n(要大于等于0)在==当前线程== 初始化CountDownLatch方法指定。当前线程调用 CountDownLatch的await()方法阻塞当前线程,等待其他调用CountDownLatch对象的CountDown()方法的线程执行完毕。 其他线程调用该CountDownLatch的CountDown()方法,该方法会把n-1,直到所有线程执行完成,n等于0,==当前线程==就恢复执行。
##### CountDownLatch
“`
public class CountDownLatch {
/**
* Synchronization control For CountDownLatch.
* Uses AQS state to represent count.
*/
private static final class Sync extends AbstractQueuedSynchronizer {
private static final long serialVersionUID = 4982264981922014374L;
Sync(int count) {
setState(count);
}
...
}
...
public void await() throws InterruptedException {
sync.acquireSharedInterruptibly(1);
}
public boolean await(long timeout, TimeUnit unit)
throws InterruptedException {
return sync.tryAcquireSharedNanos(1, unit.toNanos(timeout));
}
...
}
“`
##### AbstractQueuedSynchronizer
“`
public abstract class AbstractQueuedSynchronizer
extends AbstractOwnableSynchronizer
implements java.io.Serializable {
…
/**
* The synchronization state.
*/
private volatile int state;
…
}
“`
##### 注意 AbstractQueuedSynchronizer中的state是使用 volatile 修饰的,该值会立刻写入到主存中。