您的位置:首页 > 编程语言 > Java开发

Java多线程之concurrent包(五)——CyclicBarrier

2016-03-03 14:41 399 查看
CyclicBarrier

当线程数达到了CyclicBarrier初始时规定的数目时,所有进入等待状态的线程被唤醒并继续。 后续线程进入,则计数器重新计数,一直循环。

CyclicBarrier就象它名字的意思一样,可看成是个障碍, 所有的线程必须到齐后才能一起通过这个障碍。

CyclicBarrier初始时还可带一个Runnable的参数, 此Runnable任务在CyclicBarrier的数目达到后,所有其它线程被唤醒前被执行。

如下代码:

public class TestCyclicBarrier {
public static void main(String[] args) {
ExecutorService exec = Executors.newCachedThreadPool();
final Random random=new Random();

final CyclicBarrier barrier=new CyclicBarrier(4,new Runnable(){
@Override
public void run() {
System.out.println("所有的进程数目都齐备了,准备一起做了!");
}});

for(int i=0;i<8;i++){
exec.execute(new Runnable(){
@Override
public void run() {
try {
Thread.sleep(random.nextInt(1000));
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"进入了");
try {
barrier.await();//达到指定数目的barrier后,调用barrier中的run方法
} catch (InterruptedException e) {
e.printStackTrace();
} catch (BrokenBarrierException e) {
e.printStackTrace();
}
}});
}
exec.shutdown();
}
}


运行结果如下:

pool-1-thread-4进入了
pool-1-thread-7进入了
pool-1-thread-2进入了
pool-1-thread-1进入了
所有的进程数目都齐备了,准备一起做了!
pool-1-thread-5进入了
pool-1-thread-8进入了
pool-1-thread-6进入了
pool-1-thread-3进入了
所有的进程数目都齐备了,准备一起做了!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java 多线程