Java并发编程之栅栏(CyclicBarrier)详解

栅栏类似闭锁,但是它们是有区别的. 闭锁用来等待事件,而栅栏用于等待其他线程.什么意思呢?就是说闭锁用来等待的事件就是countDown事件,只有该countDown事件执行后所有之前在等待的线程才有可能继续执行;而栅栏没有类似countDown事件控制线程的执行,只有线程的await方法能控制等待的线程执行.

CyclicBarrier强调的是n个线程,,大家相互等待,只要有一个没完成,所有人都得等着。

场景分析:10个人去春游,规定达到一个地点后才能继续前行.代码如下

import java.util.concurrent.BrokenBarrierException;import java.util.concurrent.CyclicBarrier;class CyclicBarrierWorker implements Runnable {private int id;private CyclicBarrier barrier;public CyclicBarrierWorker(int id, final CyclicBarrier barrier) {this.id = id;this.barrier = barrier;}() {// TODO Auto-generated method stubtry {System.out.println(id + ” th people wait”);barrier.await(); // 大家等待最后一个线程到达} catch (InterruptedException | BrokenBarrierException e) {// TODO Auto-generated catch blocke.printStackTrace();}}}{(String[] args) {int num = 10;CyclicBarrier barrier = new CyclicBarrier(num, new Runnable() {() {// TODO Auto-generated method stubSystem.out.println(“go on together!”);}});for (int i = 1; i <= num; i++) {new Thread(new CyclicBarrierWorker(i, barrier)).start();}}}

输出

th people th people th people th people wait10 th people waitgo on together!

人若软弱就是自己最大的敌人

Java并发编程之栅栏(CyclicBarrier)详解

相关文章:

你感兴趣的文章:

标签云: