java并发学习----CountDownLatch

来源:互联网 发布:matlab 二维矩阵画图 编辑:程序博客网 时间:2024/05/18 03:40

java并发学习—-CountDownLatch

CountDownLatch实际上是一个计数器,能使一个线程在其他线程执行完之后再执行,它是原子性的,同时只有一个线程去操作它。它是通过一个计数器来实现的,计数器的初始值就是首先需要执行线程的数量,当数量减为零,表示所有的线程均已执行完了,然后再执行之后需要执行的线程。

主要有两个方法,await()和countDown(),其中调用await()方法的线程将一直阻塞等待,直到计数器为0,调用countDown(),计数器会减一,当为0的时候,调用await()方法 的线程才会执行。

下面是一个具体的例子,当启动多个框架的时候,主框架会依赖其他的自框架,只有自框架启动完成了,主框架才能启动,这时候就可以用CountDownLatch

public class SubFramework implements Runnable {    private String name;    private CountDownLatch countDownLatch;    public SubFramework(String name, CountDownLatch countDownLatch) {        this.name = name;        this.countDownLatch = countDownLatch;    }    @Override    public void run() {        System.out.println(name + "正在启动...");        try {            TimeUnit.SECONDS.sleep(new Random().nextInt(10));        } catch (InterruptedException e) {            e.printStackTrace();        }        System.out.println(name + "启动完成...");        this.countDownLatch.countDown();    }}
public class MainFramework implements Runnable{    private CountDownLatch countDownLatch;    public MainFramework(CountDownLatch countDownLatch) {        this.countDownLatch = countDownLatch;    }    @Override    public void run() {        System.out.println("依赖框架未启动完成...");        try {            countDownLatch.await();        } catch (InterruptedException e) {            e.printStackTrace();        }        System.out.println("依赖框架已启动完成,启动主框架....");    }}
public class CountDownlatchDemo {    public static void main(String[] args){        ExecutorService executorService= Executors.newCachedThreadPool();        CountDownLatch countDownLatch=new CountDownLatch(4);        SubFramework subFramework1=new SubFramework("sub1",countDownLatch);        SubFramework subFramework2=new SubFramework("sub2",countDownLatch);        SubFramework subFramework3=new SubFramework("sub3",countDownLatch);        SubFramework subFramework4=new SubFramework("sub4",countDownLatch);        MainFramework mainFramework=new MainFramework(countDownLatch);        executorService.execute(mainFramework);        executorService.execute(subFramework3);        executorService.execute(subFramework4);        executorService.execute(subFramework1);        executorService.execute(subFramework2);        executorService.shutdown();    }}

输出结果

依赖框架未启动完成…
sub3正在启动…
sub4正在启动…
sub1正在启动…
sub2正在启动…
sub1启动完成…
sub2启动完成…
sub4启动完成…
sub3启动完成…
依赖框架已启动完成,启动主框架….

以上 ,只有子框架先启动了,计数器一直减到0,主框架才会启动。

原创粉丝点击