CountDownLatch是java.util.concurrent包下的一个工具类,用于多个线程初始化 操作用的,对于初始化需要多个线程完成,主函数需要等待其他子线程完成,然后进行主函数的逻辑,其中构造函数中,需要传递Integer类型数据,表示需要countDown()执行几次,通常多少个线程初始化操作,就设置为几
实际案例中,我们使用Zookeeper,获取连接的情况中,我们让主线程等待,知道连接成功后,再执行Zookeeper操作
CountDownLatch案例
注意CountDownLatch的构造方法,countDown()、await()这三个方法,即可。
package yellowcong.day10_06;
import java.util.concurrent.CountDownLatch;
/**
* 创建日期:2017年10月6日 <br/>
* 创建用户:yellowcong <br/>
* 功能描述:
*/
public class CountDownDemo {
public static void main(String[] args) {
//这个是java.util.concurrent包下的一个工具类,用于多个线程初始化 操作用的
//这个对象有原子性,不会由于是多线程的导致数据问题
//里面的2 等于 需要两次 countDown 才可以解除等待状态
final CountDownLatch countDownLatch = new CountDownLatch(2);
//这是第一个主线程,等待其他子线程初始化完成后,执行主线程方法
new Thread(new Runnable() {
public void run() {
try {
System.out.println(Thread.currentThread().getName()+"\t主程序等待执行");
countDownLatch.await();
System.out.println(Thread.currentThread().getName()+"\t执行成功");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
},"主线程").start();
new Thread(new Runnable() {
public void run() {
try {
Thread.sleep(500);
System.out.println(Thread.currentThread().getName()+"\t执行初始化操作。。。。");
countDownLatch.countDown();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
},"子线程 1").start();
new Thread(new Runnable() {
public void run() {
try {
Thread.sleep(500);
System.out.println(Thread.currentThread().getName()+"\t执行初始化操作。。。。");
countDownLatch.countDown();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
},"子线程 2").start();
}
}
测试结果
主线程等待初始化过程中,await()函数是阻塞的,需要等待其他子线程完成初始化操作后,自己才可以接着运行。