简介
当线程执行数量达到你规定的数量时,被阻塞的线程才会继续运行。
应用
现在有一个需求,要计算在多线程环境下耗时
如下代码:
public class ThreadCountDownLatch {
public static void main(String[] args) {
long start = System.currentTimeMillis();//开始时间
for (int i = 0;i<5;i++) {
new Thread(new Runnable() {
public void run() {
System.out.println("子线程执行");
}
}).start();
}
long end = System.currentTimeMillis();//结束时间
System.out.println("耗时:"+(end - start)+"毫秒");
}
}
上述代码会出现这种情况:主线程已经跑完了,但是子线程还在执行。
就是说主线程是计算时间,但是还有子线程执行,如何让主线程计算时间的代码最后执行呢?
使用CountDownLatch:
public class ThreadCountDownLatch {
public static void main(String[] args) throws InterruptedException {
CountDownLatch countDownLatch = new CountDownLatch(5);//5 就代表线程数量
long start = System.currentTimeMillis();//开始时间
for (int i = 0;i<5;i++) {
new Thread(new Runnable() {
public void run() {
System.out.println("子线程执行");
countDownLatch.countDown();//当线程执行完毕后减一
}
}).start();
}
countDownLatch.await();//main线程阻塞,直到计数器为0,才会继续往下执行!
long end = System.currentTimeMillis();//结束时间
System.out.println("耗时:"+(end - start)+"毫秒");
}
}
如果不用CountDownLatch也可以实现,在countDownLatch.await()处改成while(true)的判断线程是否执行完毕,执行完毕break掉,
因为CountDownLatch底层是AQS(抽象的队列式的同步器),所以比我们写的效率高啊