CountDownLatch基本概念
- 共享锁,用于在线程之间进行操作同步的工具类。
共享锁就是在同一时刻允许多个线程持有的锁。获得共享锁的线程只能读取临界区的数据,不能修改临界区的数据。
- CountDownLatch可以指定一个计数值,在并发环境下由线程进行减一操作,当计数值变为0之后,被await方法阻塞的线程将会唤醒。
代码练习
public class Person implements Runnable{
private final CountDownLatch doneSignal;
private final int i;
public Person(CountDownLatch doneSignal, int i) {
this.doneSignal = doneSignal;
this.i = i;
}
@Override
public void run() {
System.out.println("第"+i+"个人已到");
doneSignal.countDown();
}
}
public class Driver {
private static final int N = 100;
public static void main(String[] args) throws InterruptedException {
CountDownLatch doneSignal = new CountDownLatch(N);
ExecutorService executorService = Executors.newFixedThreadPool(10);
for (int i =0;i<N;i++){
executorService.submit(new Person(doneSignal,i));
}
doneSignal.await();
System.out.println("人到齐,开车!");
}
}
部分输出:
实现原理探究
public class CountDownLatch {
/**
* Synchronization control For CountDownLatch.
* Uses AQS state to represent count.
*/
private static final class Sync extends AbstractQueuedSynchronizer {
...
...
...
}
}
CountDownLatch是使用AQS实现的。使用AQS的状态变量来存放计数器的值。
countdown()
方法:原子性递减AQS的状态值。
await()
方法:当前线程会被放入AQS的阻塞队列等待计数器为0再返回。
《Java并发编程之美》
《Java高并发核心编程(卷2)》