Java多线程之CountDownLatch的使用

来源:互联网 发布:网店美工培训课程 编辑:程序博客网 时间:2024/06/05 05:54

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()函数是阻塞的,需要等待其他子线程完成初始化操作后,自己才可以接着运行。

这里写图片描述