CountDownLatch:让一些线程阻塞直到另外一些线程完成后才被唤醒。CountDownLatch主要有两个方法,当一个或多个线程调用await方法时,调用线程会被阻塞,其他线程调用countDown方法计数器减1(调用countDown方法时线程不会阻塞),当计数器的值变为0,因调用await方法被阻塞的线程会被唤醒,继续执行
场景:假设我们现在教室里面一共有6个人,分别为5个学生和一个老师,我们要求老师必须是最后一个离开教室的。
未使用CountDownLatch的代码如下:
package com.mszl.thread;
/**
* 功能:CountDownLatch演示
* 备注:更多资料请访问 http://www.91mszl.com
* @author bobo teacher
*/
public class CountDownLatchDemo{
public static void main(String[] args) {
for(int i=1; i<=5; i++){
Thread t=new Thread(new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + " 离开教室");
}
});
t.start();
}
System.out.println(Thread.currentThread().getName() + " 老师最后一个离开教室");
}
}
执行结果:
Thread-1 离开教室
main 老师最后一个离开教室
Thread-0 离开教室
Thread-2 离开教室
Thread-3 离开教室
Thread-4 离开教室
我们发现结果并不是我们想好的。
使用CountDownLatch后的代码如下:
package com.mszl.thread;
import java.util.concurrent.CountDownLatch;
/**
* 功能:CountDownLatch演示
* 备注:更多资料请访问 http://www.91mszl.com
* @author bobo teacher
*/
public class CountDownLatchDemo {
public static void main(String[] args) throws InterruptedException {
CountDownLatch cdl=new CountDownLatch(5);
for(int i=1; i<=5; i++){
Thread t=new Thread(new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + " 离开教室");
cdl.countDown(); // 就是每次cdl的数量减1
}
});
t.start();
}
cdl.await(); // 线程阻塞,直到计数器变成0其线程才被唤醒
System.out.println(Thread.currentThread().getName() + " 老师最后一个离开教室");
}
}
执行结果:
Thread-0 离开教室
Thread-2 离开教室
Thread-1 离开教室
Thread-3 离开教室
Thread-4 离开教室
main 老师最后一个离开教室