视频链接:https://pan.baidu.com/s/1HFSB76lgTwvpU9sgAdkHSQ 密码:6o0l
源码链接:https://pan.baidu.com/s/1oASdYOV_I9Yo6HF40WboYg 密码:ke1g
API链接:http://tool.oschina.net/apidocs/apidoc?api=jdk-zh
CyclicBarrier:一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point)。在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此时 CyclicBarrier 很有用。因为该 barrier 在释放等待线程后可以重用,所以称它为循环 的 barrier。(说白了就和视频中的开会差不多,就是等人都到齐了再开会,CyclicBarrier亦是如此,线程没执行完、或者报错就不会执行 await() 方法)
下面的案例中使用到的方法:
int | await() 在所有参与者都已经在此 barrier 上调用 await 方法之前,将一直等待。 |
案例:以十个人开会为例,等十个人都到齐了,会议才开始
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
public class Demo2 {
//会议方法,在调用await方法之前,陆续等待会议开始,在都到齐了之后,通过await方法,才能执行发言
public void meeting(CyclicBarrier barrier){
System.out.println(Thread.currentThread().getName()+ " 到达会议室,等待开会...");
try {
barrier.await();
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+ " 到达会议室后开始发言...");
}
//主方法,模拟了十个人到达会议,一个人是一个线程
public static void main(String[] args) {
final Demo2 demo2 = new Demo2();
final CyclicBarrier barrier = new CyclicBarrier(10, new Runnable() {
@Override
public void run() {
System.out.println("会议开始...");
}
});
for(int i=0;i<10;i++){
new Thread(new Runnable() {
@Override
public void run() {
demo2.meeting(barrier);
}
}).start();
}
}
}
运行效果:
Thread-0 到达会议室,等待开会...
Thread-2 到达会议室,等待开会...
Thread-5 到达会议室,等待开会...
Thread-1 到达会议室,等待开会...
Thread-4 到达会议室,等待开会...
Thread-9 到达会议室,等待开会...
Thread-7 到达会议室,等待开会...
Thread-3 到达会议室,等待开会...
Thread-8 到达会议室,等待开会...
Thread-6 到达会议室,等待开会...
会议开始...
Thread-6 到达会议室后开始发言...
Thread-8 到达会议室后开始发言...
Thread-3 到达会议室后开始发言...
Thread-5 到达会议室后开始发言...
Thread-7 到达会议室后开始发言...
Thread-4 到达会议室后开始发言...
Thread-9 到达会议室后开始发言...
Thread-1 到达会议室后开始发言...
Thread-2 到达会议室后开始发言...
Thread-0 到达会议室后开始发言...
总结:CyclicBarrier类的await方法,就是所有的线程都结束后,才能通过await方法,进行下一步操作。