java并发学习----CountDownLatch

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,主框架才会启动。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值