简单认识下CountDownLatch 闭锁
使用场景:可以延迟线程的进度直到其到达终止状态,闭锁可以用来确保某些活动直到其他活动都完成才继续执行;
简单认识CountDownLatch在多线程中的使用方式:
package com.pccc.pactera.juc01;
import java.util.concurrent.CountDownLatch;
/**
* CountDownLatch 闭锁:在完成某些运算时,只有其他所有线程的运算全部完成,当前运算才继续执行
* 闭锁可以延迟线程的进度直到其到达终止状态,闭锁可以用来确保某些活
* 动直到其他活动都完成才继续执行
* @author zhao
*
*/
public class TestCountDownLatch {
public static void main(String[] args) {
final CountDownLatch latch1 = new CountDownLatch(5);//初始线程数为5, 每次创建线程需要减1
LatchDemo ld = new LatchDemo(latch1);
long start = System.currentTimeMillis();
for (int i = 0; i < 5; i++) {
new Thread(ld).start();
}
try {
latch1.await();//执行子线程时,主线程等待
} catch (InterruptedException e) {//异常中断
e.printStackTrace();
}
long end = System.currentTimeMillis();
System.out.println("耗时时间为:"+(end-start));
}
}
class LatchDemo implements Runnable {
private CountDownLatch latch;
public LatchDemo(CountDownLatch latch) {// 构造器
this.latch = latch;
}
@Override
public void run() {
synchronized (this) {//加锁是为了处理线程安全问题
try {
//打印5000以内的偶数
for (int i = 0; i < 5000; i++) {
if (i % 2 == 0) {
System.out.println(i);
}
}
} finally{
//为保证必须执行,放在finally代码块
System.out.println("11");
latch.countDown();//计数器递减1
}
}
}
}
可以在所线程去做统计类处理时使用,每个线程单独做自己的事,所有其他线程执行完后再执行;