一、导言
公交车来了,小明、小红要等小军来才上公交车,但是小军迟迟不来,于是小明和小红都迟到了。
CountDownLatch
直译为闭锁,CountDown就是表示倒计时的意思,Latch表示门栓的意思,CountDownLatch
和门栓的含义有点像,可以看做代码执行时的一个门栓,条件不满足就进不了“门”(代码无法继续执行),此处的条件就是“latch”数字为0。
常见于以下几种使用场景(如果还有其他的使用场景,麻烦在评论区补充出来,欢迎交流沟通)。
- 实现最大并行性:当所有线程都满足与某个条件(latch为0)时才能继续执行,在这之前都在等待。
- 有先后顺序的分工合作:例如应用程序启动类要确保在处理用户请求前,所有N个外部系统已经启动和运行了。
- 死锁检测:一个非常方便的使用场景是,你可以使用n个线程访问共享资源,在每次测试阶段的线程数目是不同的,并尝试产生死锁。
二、基本使用
2.1 基本api
一般来说,使用CountDownLatch
只会用到await
的普通或超时版本、countDown
方法、以及一个构造方法。
@Test
public void latch() throws InterruptedException {
CountDownLatch latch = new CountDownLatch(4/*需要countDown4次*/);
long maxLatch = latch.getCount();
for (int i = 0; i < /*只countDown了3次*/maxLatch - 1; i++) {
new Thread(() -> {
// 对于每个线程都输出线程名
System.out.println(Thread.currentThread().getName());
sleep(1);//沉睡一秒
latch.countDown()