原理
countDownLatch是在java1.5被引入,跟它一起被引入的工具类还有CyclicBarrier、Semaphore、concurrentHashMap和BlockingQueue。
存在于java.util.cucurrent包下。
countDownLatch这个类使一个线程等待其他线程各自执行完毕后再执行。
是通过一个计数器来实现的,计数器的初始值是线程的数量。每当一个线程执行完毕后,计数器的值就-1,
当计数器的值为0时,表示所有线程都执行完毕,然后在闭锁上等待的线程就可以恢复工作了。
场景:班长+6个同学上自习,班长需等6为同学全部离开教室后,才锁门离开
public class CountDownLatchDemo {
public static final int stu = 6;
public static void main(String[] args) {
System.out.println("自习中 。。。\n");
CountDownLatch countDownLatch = new CountDownLatch(6);
for(int i=0; i<6; i++) {
final int j = i;
new Thread(()->{
try {
Thread.sleep(1000);
System.out.println("同学 "+j+" 结束自习,离开教室 。。。\n");
countDownLatch.countDown();
} catch (InterruptedException e) {
e.printStackTrace();
}
}, String.valueOf(i)).start();
}
try {
countDownLatch.await();
System.out.println("\n同学已经全部离开,班长锁门离开 。。。");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}