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)》

CountDownLatch是一个用于线程间同步的工具类,基于AQS(AbstractQueuedSynchronizer)实现。它允许设置一个计数器,线程执行完成后调用countDown()方法减少计数,当计数器归零时,所有等待在await()方法上的线程将被释放并继续执行。示例代码展示了如何在多线程环境中使用CountDownLatch确保所有线程到达某个点后,主程序再继续执行。
13

被折叠的 条评论
为什么被折叠?



