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,主框架才会启动。
阅读全文
0 0
- java并发学习----CountDownLatch
- Java并发学习(十七)-并发工具CountDownLatch
- Java并发学习笔记(三)-闭锁CountDownLatch
- 深入学习java并发编程:CountDownLatch、CyclicBarrier
- Java并发同步器--CountDownLatch
- Java并发之CountDownLatch
- Java并发之CountDownLatch
- Java并发编程:CountDownLatch
- Java并发编程---CountDownLatch
- 【java并发】CountDownLatch
- JAVA 并发编程CountDownLatch
- Java并发学习笔记(14) 闭锁(CountDownLatch)
- Java并发学习笔记(14) 闭锁(CountDownLatch)
- [Java并发包学习五]CountDownLatch和CyclicBarrier介绍
- [Java并发包学习五]CountDownLatch和CyclicBarrier介绍
- [Java并发包学习五]CountDownLatch和CyclicBarrier介绍
- [Java并发包学习五]CountDownLatch和CyclicBarrier介绍
- [Java并发包学习五]CountDownLatch和CyclicBarrier介绍
- mysql中导出数据字典
- jqeury 读取 另一个文件
- const详解
- 以太坊历史
- Mysql数据库操作
- java并发学习----CountDownLatch
- OSI 七层模型详解
- 530. Minimum Absolute Difference in BST
- HDU4764 Stone 巴什博奕|签到
- Mongo聚合
- 树莓派3移植安卓系统指导
- Java队列
- VS2012下如何生成和调用DLL
- HDU 2580 a simple stone game K倍减法博弈游戏