CountDownLatch 又叫“闭锁” 相当一扇门,当所有线程没有到达之前,锁一直是关闭,没有任何线程可以通过。类以一个计数器,计数所有线程是否已经到达,或者资源是否已经初始化完成,不过这个计数器是一个
倒计的。一般有以下几种情况用到CountDownLatch:
1.确保某个操作或计算之前,所有资源R已经被初始化。
2.要启动某些服务,必须等待别的服务启动。
3.类似于在线网游,团战必须等待所有玩家都到才可以开始。
CountDownLatch 初始化创建的时候给计数器一个正数,也就是我们所说要多少人才能开始,或者等待数量,每个事件到达的时候,计数器减1 当计数器为0的时候,所有事件都已经发生。
下面我们来看一下具体用法:
package javaThread;
import java.util.concurrent.CountDownLatch;
public class CountDown {
public static void main(String[] args) {
final CountDownWait count = new CountDownWait();
Thread thread = new Thread("test 1") {
@Override
public void run() {
super.run();
synchronized (this) {
try {
count.latch.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
for (int i = 0; i < 100; i++) {
if (i % 2 == 0) {
System.out.println(" CountDown !!!!!!!" + i);
;
}
}
}
}
};
thread.start();
Thread thread2 = new Thread("test 22222") {
@Override
public void run() {
super.run();
synchronized (this) {
for (int i = 0; i < 100; i++) {
if (i % 2 == 0) {
System.out.println(" CountDown ########" + i);
}
}
count.latch.countDown();
}
}
};
thread2.start();
}
private static class CountDownWait {
public final CountDownLatch latch = new CountDownLatch(1);
}
}
当前 的计数器为1 就相当于锁。线程1 等待,线程2 的事件到来才开始执行。
我们也可以设置 一个起始门,等待所以事件到达再开始执行,就好像我们跑步一样,设置一条起跑线,等所有线程都来的时候一起开始执行。