1.定义
CountDownLatch这个类能够使一个线程等待其他线程完成各自的工作后再执行。CountDownLatch是通过一个计数器来实现的,计数器的初始值为线程的数量。每当一个线程完成了自己的任务后,计数器的值就会减1。当计数器值到达0时,它表示所有的线程已经完成了任务,然后在闭锁上等待的线程就可以恢复执行任务。
2.区别CyclicBarrier
3.主要方法
countDown:主线程必须在启动其他线程后立即调用CountDownLatch.await()方法。这样主线程的操作就会在这个方法上阻塞,直到其他线程完成各自的任务。
await:其他N 个线程必须引用闭锁对象,因为他们需要通知CountDownLatch对象,他们已经完成了各自的任务。这种通知机制是通过 CountDownLatch.countDown()方法来完成的;每调用一次这个方法,在构造函数中初始化的count值就减1。所以当N个线程都调 用了这个方法,count的值等于0,然后主线程就能通过await()方法,恢复执行自己的任务。
4.应用场景
5.在登陆后抽题的过程中使用的等待n个线程完成各自任务。
package test.pool;
import java.util.concurrent.CountDownLatch;
public class testCountDownLatch {
public static void main(String[] args) {
final CountDownLatch countDownLatch=new CountDownLatch(4);
new Thread(){
public void run(){
try {
System.out.println(Thread.currentThread().getName()+"抽取听力题");
Thread.sleep(3000);
countDownLatch.countDown();
} catch (Exception e) {
e.printStackTrace();
}
}
}.start();
new Thread(){
public void run(){
try {
System.out.println(Thread.currentThread().getName()+"抽取单选题");
Thread.sleep(3000);
countDownLatch.countDown();
} catch (Exception e) {
e.printStackTrace();
}
}
}.start();
new Thread(){
public void run(){
try {
System.out.println(Thread.currentThread().getName()+"抽取复合式题");
Thread.sleep(3000);
countDownLatch.countDown();
} catch (Exception e) {
e.printStackTrace();
}
}
}.start();
new Thread(){
public void run(){
try {
System.out.println(Thread.currentThread().getName()+"抽取作文题");
Thread.sleep(3000);
countDownLatch.countDown();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}.start();
try {
Thread.sleep(1000);
System.out.println("4个线程正在抽题呢");
countDownLatch.await();
System.out.println("4个子线程已经执行完毕,继续执行主线程");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
Thread-0抽取听力题
Thread-1抽取单选题
Thread-2抽取复合式题
Thread-3抽取作文题
4个线程正在抽题呢
4个子线程已经执行完毕,继续执行主线程