CountDownLatch是一个同步辅助类,犹如倒计时计数器,创建对象时通过构造方法设置初始值,调用CountDownLatch对象的await()方法则处于等待状态,调用countDown()方法就将计数器减1,当计数到达0时,则所有等待者或单个等待者开始执行。
public static void main(String[] args) { ExecutorService service = Executors.newCachedThreadPool(); //创建一个线程池 final CountDownLatch cdOrder = new CountDownLatch(1); //state值为1 final CountDownLatch cdAnswer = new CountDownLatch(3); //state值为3 for(int i=0;i<3;i++){ Runnable runnable = new Runnable(){ public void run(){ try { System.out.println(""线程"" + Thread.currentThread().getName() + ""正准备接受命令""); cdOrder.await(); //等待直到cdOrder的state值为0时,继续往下执行 System.out.println(""线程"" + Thread.currentThread().getName() + ""已接受命令""); TimeUnit.SECONDS.sleep(3); //线程休眠3秒 System.out.println(""线程"" + Thread.currentThread().getName() + ""回应命令处理结果""); cdAnswer.countDown(); //cdAnswer的state值减1 } catch (Exception e) { e.printStackTrace(); } } }; service.execute(runnable); //为线程池添加任务 } try { TimeUnit.SECONDS.sleep(5); //线程休眠5秒 System.out.println(""线程"" + Thread.currentThread().getName() + ""即将发布命令""); cdOrder.countDown(); //cdOrder的state值减1 System.out.println(""线程"" + Thread.currentThread().getName() + ""已发送命令,正在等待结果""); cdAnswer.await(); //等待直到cdAnswer的state值为0时,继续往下执行 System.out.println(""线程"" + Thread.currentThread().getName() + ""已收到所有响应结果""); } catch (Exception e) { e.printStackTrace(); } service.shutdown(); //任务结束,停止线程池的所有线程 }
相关推荐
主要介绍了JAVA多线程CountDownLatch的使用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
文章目录1 原理简介2 具体使用方法2.1 demo1 — await不传入时间,保证当前线程的其他操作在最后执行2.2 demo2 — await传入时间t,当前线程等其他线程时间t后就运行其他操作2.3 发令枪 源码地址:...
CountDownLatch使用实例 - 初始化时,设置计数(count)值,也就是闭锁需要等待的线程数。 - 主线程必须在启动其他线程后立即调用 CountDownLatch.await() 方法,这样主线程的操作就会在这个方法上阻塞,直到其他...
于是乎到现在的Hibernate、MyBatis、Spring、Spring MVC、AQS、ThreadPoolExecutor、CountDownLatch使用场景和核心源码分析。 感觉自己还是真的菜鸡,有太多框架的底层实现都不怎么了解。 当山头被一座一座攻克时,...
java并发编程中CountDownLatch和CyclicBarrier的使用借鉴.pdf
《java并发编程》中CountDownLatch和CyclicBarrier用法实例大全,几乎包含了所有重要的用法
利用 CountDownLatch 类实现线程同步,而不用回调机制。详见我的博文 http://blog.csdn.net/kroclin/article/details/37956949
mybaits 多线程 实现数据批量插入 (运用CountDownLatch实现闭锁) 1、mybatis批处理 2、数据分批量查询 3、数据分批量插入
目录 CountDownLatch是什么? CountDownLatch如何工作? 在实时系统中的应用场景 应用范例 常见的面试题 代码样例
CountDownLatch与thread.join()的区别
在网上找的一个CountDownLatch的学习demo,感觉很不错,就摘抄过来了
java并发编程中CountDownLatch和CyclicBarrier的使用.pdf
NULL 博文链接:https://cpjsjxy.iteye.com/blog/2272451
CountDownLatch Demo
Java并发编程一CountDownLatch、CyclicBarrier、Semaphore初使用 CountDownLatch、CyclicBarrier、Semaphore这些线程协作工具类是基于AQS的,看完这篇博客后可以去看下面这篇博客,了解它们是如何实现的。 Java并发...
并发编程之CountDownLatch
3.2 使用CountDownLatch实现同步 主线程等待多个线程完成 4.1 场景介绍 4.2 使用CountDownLatch实现等待 CountDownLatch的其他应用场景 5.1 倒计时计时器 5.2 同时开始任务 5.3 等待多个资源就绪 CountDownLatch与...
主要为大家详细介绍了CountDownLatch的使用说明,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
主要介绍了如何使用CountDownLatch同步java多线程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下