Java5中,添加了障礙器類,為了適應一種新的設計需求,比如一個大型的任務,常常需要分配好多子任務去執行,只有當所有子任務都執行完成時候,才能執行主任務,這時候,就可以選擇障礙器了。
障礙器是多線程并發控制的一種手段,用法很簡單。下面給個例子:
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
publicclass Test {
publicstaticvoid 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 {
publicvoid 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;
} publicvoid 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
從執行結果可以看出,所有子任務完成的時候,主任務執行了,達到了控制的目標。
Java線程:大總結
Java線程是Java語言中一個非常重要的部分,Java5之前,多線程的語言支持還是比較弱的,內容也較少,寫一個復雜的多線程程序是相當有挑戰性的。