障礙器是多線程並發控制的一種手段,用法很簡單。下面給個例子:
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
/**
* Java線程:新特征-障礙器
*
* @author leizhimin
*/
public class Test {
public static void main(String[] args) {
//創建障礙器,並設置MainTask為所有定數量的線程都達到障礙點時候所要執行的任務(Runnable)
CyclicBarrier cb = new CyclicBarrier(7, new MainTask());
new SubTask("A", cb).start();
new SubTask("B", cb).start();
new SubTask("C", cb).start();
new SubTask("D", cb).start();
new SubTask("E", cb).start();
new SubTask("F", cb).start();
new SubTask("G", cb).start();
}
}
/**
* 主任務
*/
class MainTask implements Runnable {
public void run() {
System.out.println(">>>>主任務執行了!<<<<");
}
}
/**
* 子任務
*/
class SubTask extends Thread {
private String name;
private CyclicBarrier cb;
SubTask(String name, CyclicBarrier cb) {
this.name = name;
this.cb = cb;
}
public void run() {
System.out.println("[子任務" + name + "]開始執行了!");
for (int i = 0; i < 999999; i++) ; //模擬耗時的任務
System.out.println("[子任務" + name + "]開始執行完成了,並通知障礙器已經完成!");
try {
//通知障礙器已經完成
cb.await();
} catch (InterruptedException e) {
e.printStackTrace();
} catch (BrokenBarrierException e) {
e.printStackTrace();
}
}
}
運行結果:
[子任務E]開始執行了!
[子任務E]開始執行完成了,並通知障礙器已經完成!
[子任務F]開始執行了!
[子任務G]開始執行了!
[子任務F]開始執行完成了,並通知障礙器已經完成!
[子任務G]開始執行完成了,並通知障礙器已經完成!
[子任務C]開始執行了!
[子任務B]開始執行了!
[子任務C]開始執行完成了,並通知障礙器已經完成!
[子任務D]開始執行了!
[子任務A]開始執行了!
[子任務D]開始執行完成了,並通知障礙器已經完成!
[子任務B]開始執行完成了,並通知障礙器已經完成!
[子任務A]開始執行完成了,並通知障礙器已經完成!
>>>>主任務執行了!<<<<
Process finished with exit code 0
從執行結果可以看出,所有子任務完成的時候,主任務執行了,達到了控制的目標。
出處:http://lavasoft.blog.51cto.com/62575/222738