可以理解为循环栅栏,栅栏就是一种障碍物.假如我们将计数器设置为10,那么凑齐第一批10个线程后,计数器就会归零,然后接着凑齐下一批10个线程,这就是循环栅栏的含义.
构造器:
  1. public CyclicBarrier(int parties, Runnable barrierAction)
parties:计数总数,也就是参与的线程总数. barrierAction 当计数器一次完成计数后,系统会执行的动作
 
下面代码展示了 司令要求10个士兵去完成任务,先集合10个然后去一起完成任务,等全部完成后 司令才会宣布任务完成!
  1. public class CyclicBarrierDemo {
  2. public static class Soldier implements Runnable {
  3. private String soldier;
  4. private final CyclicBarrier cyclic;
  5.  
  6. public Soldier(CyclicBarrier cyclic, String soldier) {
  7. this.soldier = soldier;
  8. this.cyclic = cyclic;
  9. }
  10.  
  11. /**
  12. * When an object implementing interface <code>Runnable</code> is used
  13. * to create a thread, starting the thread causes the object's
  14. * <code>run</code> method to be called in that separately executing
  15. * thread.
  16. * <p>
  17. * The general contract of the method <code>run</code> is that it may
  18. * take any action whatsoever.
  19. *
  20. * @see Thread#run()
  21. */
  22. @Override
  23. public void run() {
  24. try {
  25. //等待所有士兵到齐
  26. cyclic.await();
  27. doWork();
  28. //等待所有士兵完成工作
  29. cyclic.await();
  30. } catch (InterruptedException e) {//在等待过程中,线程被中断
  31. e.printStackTrace();
  32. } catch (BrokenBarrierException e) {//表示当前CyclicBarrier已经损坏.系统无法等到所有线程到齐了.
  33. e.printStackTrace();
  34. }
  35. }
  36.  
  37. void doWork() {
  38. try {
  39. Thread.sleep(Math.abs(new Random().nextInt() % 10000));
  40. } catch (InterruptedException e) {
  41. e.printStackTrace();
  42. }
  43. System.out.println(soldier + ":任务完成");
  44. }
  45.  
  46. }
  47.  
  48. public static class BarrierRun implements Runnable {
  49. boolean flag;
  50. int N;
  51.  
  52. public BarrierRun(boolean flag, int N) {
  53. this.flag = flag;
  54. this.N = N;
  55. }
  56.  
  57. /**
  58. * When an object implementing interface <code>Runnable</code> is used
  59. * to create a thread, starting the thread causes the object's
  60. * <code>run</code> method to be called in that separately executing
  61. * thread.
  62. * <p>
  63. * The general contract of the method <code>run</code> is that it may
  64. * take any action whatsoever.
  65. *
  66. * @see Thread#run()
  67. */
  68. @Override
  69. public void run() {
  70. if (flag) {
  71. System.out.println("司令:[士兵" + N + "个,任务完成!]");
  72. } else {
  73. System.out.println("司令:[士兵" + N + "个,集合完毕!]");
  74. flag = true;
  75. }
  76. }
  77. }
  78.  
  79. public static void main(String[] args) {
  80. final int N = 10;
  81. Thread[] allSoldier = new Thread[N];
  82. boolean flag = false;
  83. CyclicBarrier cyclic = new CyclicBarrier(N, new BarrierRun(flag, N));
  84. //设置屏障点,主要为了执行这个方法
  85. System.out.println("集合队伍! ");
  86. for (int i = 0; i < N; i++) {
  87. System.out.println("士兵" + i + "报道! ");
  88. allSoldier[i] = new Thread(new Soldier(cyclic, "士兵" + i));
  89. allSoldier[i].start();
  90. }
  91. }
  92. }
 
结果:

循环栅栏:CyclicBarrier(司令要求任务) 读书笔记的更多相关文章

  1. 多线程之倒计时器CountDownLatch和循环栅栏CyclicBarrier

    1.倒计时器CountDownLatch CountDownLatch是一个多线程控制工具类.通常用来控制线程等待,它可以让一个线程一直等待知道计时结束才开始执行 构造函数: public Count ...

  2. Java并发编程原理与实战二十七:循环栅栏:CyclicBarrier

    昨天我们学习了倒计数功能的等待,今天我们学习的是循环栅栏:CyclicBarrier.下面我们就开始吧: 1.CyclicBarrier简介CyclicBarrier,是JDK1.5的java.uti ...

  3. java高并发系列 - 第17天:JUC中的循环栅栏CyclicBarrier常见的6种使用场景及代码示例

    这是java高并发系列第17篇. 本文主要内容: 介绍CyclicBarrier 6个示例介绍CyclicBarrier的使用 对比CyclicBarrier和CountDownLatch Cycli ...

  4. 24.循环栅栏 CyclicBarrier

    import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CyclicBarrier; /** * ...

  5. 3.1.6 循环栅栏:CyclicBarrier

    package 第三章.循环栅栏CyclicBarrier; import java.util.concurrent.BrokenBarrierException;import java.util.c ...

  6. 《实战Java高并发程序设计》读书笔记三

    第三章 JDK并发包 1.同步控制 重入锁:重入锁使用java.util.concurrent.locks.ReentrantLock类来实现,这种锁可以反复使用所以叫重入锁. 重入锁和synchro ...

  7. 戏说java多线程之CyclicBarrier(循环栅栏)的CyclicBarrier(int parties)构造方法

    CyclicBarrier是JDK 1.5 concurrent包出现的一个用于解决多条线程阻塞,当达到一定条件时一起放行的一个类.我们先来看这样一个简单的需求. 现在我有一个写入数据的类,继承Run ...

  8. SQL 横转竖 、竖专横 (转载) 使用Dapper.Contrib 开发.net core程序,兼容多种数据库 C# 读取PDF多级书签 Json.net日期格式化设置 ASPNET 下载共享文件 ASPNET 文件批量下载 递归,循环,尾递归 利用IDisposable接口构建包含非托管资源对象 《.NET 进阶指南》读书笔记2------定义不可改变类型

    SQL 横转竖 .竖专横 (转载)   普通行列转换 问题:假设有张学生成绩表(tb)如下: 姓名 课程 分数 张三 语文 74 张三 数学 83 张三 物理 93 李四 语文 74 李四 数学 84 ...

  9. java并发之(4):Semaphore信号量、CounDownLatch计数锁存器和CyclicBarrier循环栅栏

    简介 java.util.concurrent包是Java 5的一个重大改进,java.util.concurrent包提供了多种线程间同步和通信的机制,比如Executors, Queues, Ti ...

随机推荐

  1. XAML实时显示更新插件LiveXAML

     XAML实时显示更新插件LiveXAML LiveXAML是Visual Studio的第三方扩展插件.该插件可以从Visual Studio Marketplace下载,也可以从官网下载http: ...

  2. FastReport.Net使用:[15]富文本控件使用

    富文本(Rich Text)控件用于显示Rtf格式的文本. 认识富文本编辑窗体 1.下图就是富文本的编辑窗体,乍一看就像Word一样,不过功能没有Word强大了.具体功能就不一一介绍了,用个Word的 ...

  3. 某DP题目3

    题意: 一根数轴上有n只怪物,第i个怪物所在的位置为ai,另有m个特殊点,第i个特殊点所在的位置为bi.你可以对怪物进行移动,若两怪物相邻,那么你不能把他们分开,移动时要看作一个整体.你可以选择向左或 ...

  4. hihocoder 162周 1323 : 回文字符串

    hihocoder1323 : 回文字符串(162周) 题目链接 思路: dp; ac代码: #include<iostream> #include<cstdio> #incl ...

  5. POJ 3525 Most Distant Point from the Sea (半平面交+二分)

    Most Distant Point from the Sea Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 3476   ...

  6. 添加引用方式抛出和捕获干净的WebService异常

    转载:http://www.cnblogs.com/ahdung/p/3953431.html 说明:[干净]指的是客户端在捕获WebService(下称WS)抛出的异常时,得到的ex.Message ...

  7. 【redis】redis五大类 用法 【转载:https://www.cnblogs.com/yanan7890/p/6617305.html】

    转载地址:https://www.cnblogs.com/yanan7890/p/6617305.html

  8. cocos2dx 3.0研究(1)-- hello world程序

    1. 在mac上构建hello world很easy ./setup.py source /Users/jiangxf/.bash_profile cocos new AliGame -p com.m ...

  9. js隐藏表格的一行数据

    1.方法 document.getElementById('customerAccount_tr').style.display="";//缴纳人名称显示 document.get ...

  10. jquery省市选择案例

    1.代码实例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...