CountDownLatch

监听某个线程的初始化,等待初始化执行完毕后,通知主线程工作。延迟、阻塞的是主线程,在单个线程中。

CyclicBarrier

针对多个线程、线程池,多个线程初始化准备之后,去操作同一件事件(必须一定要所有准备才可执行,通知各的主线程去执行正常工作)。

  1. package demo2;
  2. import java.util.Random;
  3. import java.util.concurrent.BrokenBarrierException;
  4. import java.util.concurrent.CyclicBarrier;
  5. import java.util.concurrent.ExecutorService;
  6. import java.util.concurrent.Executors;
  7. /**
  8. * Created by liudan on 2017/7/30.
  9. */
  10. public class DemoCyclicBarrier {
  11. /**
  12. * 假设一个场景:3个运动员,当跑步运动员准备好了,才一起出发
  13. */
  14. static class Runner implements Runnable {
  15. private CyclicBarrier CYCLIC_BARRIER;
  16. private String name;
  17. public Runner(CyclicBarrier CYCLIC_BARRIER, String name) {
  18. this.CYCLIC_BARRIER = CYCLIC_BARRIER;
  19. this.name = name;
  20. }
  21. @Override
  22. public void run() {
  23. try {
  24. Thread.sleep(1000 * (new Random().nextInt(5)));
  25. System.err.println(name + "\t准备好了");
  26. CYCLIC_BARRIER.await();
  27. } catch (InterruptedException e) {
  28. e.printStackTrace();
  29. } catch (BrokenBarrierException e) {
  30. e.printStackTrace();
  31. }
  32. System.err.println("Go!");
  33. }
  34. public static void main(String[] args) {
  35. CyclicBarrier CYCLIC_BARRIER = new CyclicBarrier(3);
  36. ExecutorService executorService = Executors.newFixedThreadPool(3);
  37. executorService.execute(new Runner(CYCLIC_BARRIER, "1号"));
  38. executorService.execute(new Runner(CYCLIC_BARRIER, "2号"));
  39. executorService.execute(new Runner(CYCLIC_BARRIER, "2号"));
  40. executorService.shutdown();
  41. }
  42. }
  43. }
  44. 输出:
  45. 1号 准备好了
    2号 准备好了
    2号 准备好了
    Go!
    Go!
    Go!
案例2
  1. public class TestCyclicBarrier {
  2. private static final int THREAD_NUM = 5;
  3. public static class WorkerThread implements Runnable{
  4. CyclicBarrier barrier;
  5. public WorkerThread(CyclicBarrier b){
  6. this.barrier = b;
  7. }
  8. @Override
  9. public void run() {
  10. // TODO Auto-generated method stub
  11. try{
  12. System.out.println("Worker's waiting");
  13. //线程在这里等待,直到所有线程都到达barrier。
  14. barrier.await();
  15. System.out.println("ID:"+Thread.currentThread().getId()+" Working");
  16. }catch(Exception e){
  17. e.printStackTrace();
  18. }
  19. }
  20. }
  21. /**
  22. * @param args
  23. */
  24. public static void main(String[] args) {
  25. // TODO Auto-generated method stub
  26. CyclicBarrier cb = new CyclicBarrier(THREAD_NUM, new Runnable() {
  27. //当所有线程到达barrier时执行
  28. @Override
  29. public void run() {
  30. // TODO Auto-generated method stub
  31. System.out.println("Inside Barrier");
  32. }
  33. });
  34. for(int i=0;i<THREAD_NUM;i++){
  35. new Thread(new WorkerThread(cb)).start();
  36. }
  37. }
  38. }
  39. /*
  40. 以下是输出:
  41. Worker's waiting
  42. Worker's waiting
  43. Worker's waiting
  44. Worker's waiting
  45. Worker's waiting
  46. Inside Barrier
  47. ID:12 Working
  48. ID:8 Working
  49. ID:11 Working
  50. ID:9 Working
  51. ID:10 Working
  52. */

12.线程通信CyclicBarrier的更多相关文章

  1. Java线程通信

    Java线程通信 螣蛇乘雾,终为土灰. 多个线程协同工作完成某个任务时就会涉及到线程间通信问题.如何使各个线程之间同时执行,顺序执行.交叉执行等. 一.线程同时执行 创建两个线程a和b,两个线程内调用 ...

  2. Linux下c开发 之 线程通信(转)

    Linux下c开发 之 线程通信(转) 1.Linux“线程” 进程与线程之间是有区别的,不过Linux内核只提供了轻量进程的支持,未实现线程模型.Linux是一种“多进程单线程”的操作系统.Linu ...

  3. Java核心知识点学习----使用Condition控制线程通信

    一.需求 实现线程间的通信,主线程循环3次后,子线程2循环2次,子线程3循环3次,然后主线程接着循环3次,如此循环3次. 即:A->B->C---A->B->C---A-> ...

  4. .net学习之多线程、线程死锁、线程通信 生产者消费者模式、委托的简单使用、GDI(图形设计接口)常用的方法

    1.多线程简单使用(1)进程是不执行代码的,执行代码的是线程,一个进程默认有一个线程(2)线程默认情况下都是前台线程,要所有的前台线程退出以后程序才会退出,进程里默认的线程我们叫做主线程或者叫做UI线 ...

  5. JAVA基础知识之多线程——线程通信

    传统的线程通信 Object提供了三个方法wait(), notify(), notifyAll()在线程之间进行通信,以此来解决线程间执行顺序等问题. wait():释放当前线程的同步监视控制器,并 ...

  6. Linux使用定时器timerfd 和 eventfd接口实现进程线程通信

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  7. JAVA多线程提高二:传统线程的互斥与同步&传统线程通信机制

    本文主要是回顾线程之间互斥和同步,以及线程之间通信,在最开始没有juc并发包情况下,如何实现的,也就是我们传统的方式如何来实现的,回顾知识是为了后面的提高作准备. 一.线程的互斥 为什么会有线程的互斥 ...

  8. Linux下c开发 之 线程通信

    Linux下c开发 之 线程通信 1.Linux“线程” 进程与线程之间是有区别的,不过Linux内核只提供了轻量进程的支持,未实现线程模型.Linux是一种“多进程单线程”的操作系统.Linux本身 ...

  9. 第23章 java线程通信——生产者/消费者模型案例

    第23章 java线程通信--生产者/消费者模型案例 1.案例: package com.rocco; /** * 生产者消费者问题,涉及到几个类 * 第一,这个问题本身就是一个类,即主类 * 第二, ...

随机推荐

  1. 《深入浅出MyBatis技术原理与实战》——4. 映射器,5. 动态SQL

    4.1 映射器的主要元素 4.2 select元素 4.2.2 简易数据类型的例子 例如,我们需要统计一个姓氏的用户数量.应该把姓氏作为参数传递,而将结果设置为整型返回给调用者,如: 4.2.3 自动 ...

  2. centos7安装与卸载JDK

    用yum安装JDK 首先检查jdk是否安装 rpm -qa | grep java      或者   java -version 1.查看yum库中都有哪些jdk版本(暂时只发现了openjdk) ...

  3. Python进程间通信:Queue

    Python进程间通信Queue 1.Queue使用方法: Queue.qsize():返回当前队列包含的消息数量: Queue.empty():如果队列为空,返回True,反之False : Que ...

  4. win_tc使用感受

    上大学的时候一直在使用win_tc就因为使用方便,今天准备用这个工具编辑一个函数,就特意下载了一个. 没想到直接出来一个bug. sizeof(char*)结果竟然是2. 果断接卸,误人子弟啊.

  5. Linux操作命令(二)

    本次实验将介绍 Linux 命令中 mkdir.rm.mv.cp.cat.nl 命令的用法. 1.mkdir mkdir命令用来创建指定名称的目录,要求创建目录的用户在当前目录中具有写权限,并且指定的 ...

  6. 循序渐进PYTHON3(十三) --8-- DJANGO之ADMIN

    admin简单使用:   1.urls.py  2.settings.py  3.models.py from django.db import models classUserInfo(models ...

  7. scrapy抓取拉勾网职位信息(二)——拉勾网页面分析

    网站结构分析: 四个大标签:首页.公司.校园.言职 我们最终是要得到详情页的信息,但是从首页的很多链接都能进入到一个详情页,我们需要对这些标签一个个分析,分析出哪些链接我们需要跟进. 首先是四个大标签 ...

  8. Codeforces Round #307 (Div. 2) E. GukiZ and GukiZiana(分块)

    E. GukiZ and GukiZiana time limit per test 10 seconds memory limit per test 256 megabytes input stan ...

  9. ABP+NetCore+Vue.js实现增删改查

    ABP我就不多介绍了,不知道的可以自己百度 本篇开发工具VS2017,数据库SQL SERVER2012,系统Win7 1.去ABP官网下载对应的模板,下载地址:https://aspnetboile ...

  10. Line Reflection -- LeetCode

    Given n points on a 2D plane, find if there is such a line parallel to y-axis that reflect the given ...