CyclicBarrier介绍
2015-12-01 13:37
429 查看
package com.karl.concurrent.utils; import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CyclicBarrier; /** * Created by karl. */ public class CyclicBarrierTest { public static class Task implements Runnable{ private CyclicBarrier barrier; public Task(CyclicBarrier barrier){ this.barrier = barrier; } @Override public void run() { System.out.println(Thread.currentThread().getName()+" is waiting the barrier."); try { barrier.await(); } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+" cross the barrier"); } } public static void main(String[] args) { //也可以只有第一个参数,表示参与者数目,即当3个参数与者到达barrier,则跨过barrier //第二个参数是一个线程,这个表示指定数目的线程到到达barrier后,将回执行这个线程。 CyclicBarrier cb = new CyclicBarrier(3, new Runnable() { @Override public void run() { System.out.println("all parties are arrived at barrier,lets play"); } }) ; Thread t1 = new Thread(new Task(cb), "Thread 1"); Thread t2 = new Thread(new Task(cb), "Thread 2"); Thread t3 = new Thread(new Task(cb), "Thread 3"); Thread t4 = new Thread(new Task(cb), "Thread 4"); Thread t5 = new Thread(new Task(cb), "Thread 5"); Thread t6 = new Thread(new Task(cb), "Thread 6"); t1.start(); t2.start(); t3.start(); t4.start(); t5.start(); t6.start(); cb.reset(); //重新设置barrier } }
结果:
Thread 1 is waiting the barrier. Thread 2 is waiting the barrier. Thread 3 is waiting the barrier. all parties are arrived at barrier,lets play Thread 3 cross the barrier Thread 1 cross the barrier Thread 2 cross the barrier Thread 4 is waiting the barrier. Thread 5 is waiting the barrier. Thread 6 is waiting the barrier. all parties are arrived at barrier,lets play Thread 6 cross the barrier Thread 4 cross the barrier Thread 5 cross the barrier Process finished with exit code 0
相关文章推荐
- 135漏洞利用
- 问题之~SecureCRT终端只能输出无法输入
- 【LeetCode】171 Excel Sheet Column Number
- 遇到的一个坑
- 骨牌铺方格
- AlertDialog弹出框-常用几种写法
- 修改tp-wr841n-v8的flash
- TJU 2944 Mussy Paper 最大权闭合子图
- 《swift2.0 官方教程中文版》 第2章-13继承
- easyui--dialog
- 信息检索(IR)的评价指标介绍 - 准确率、召回率、F1、mAP、ROC、AUC
- acm 2048 错排公式!!!!!!!
- 【LeetCode】242 Valid Anagram
- HDU 1004 (字典树||map)
- 数根
- Autofac 组件、服务、自动装配 《第二篇》
- java里为什么使用nextLine();没有等我输入就“跳过了”?
- 企业总机技术架构
- 异步处理框架样例代码
- 递归查询所有子级