代码如下-----------------------------


package dxm.com.test;


import java.util.concurrent.CyclicBarrier;


public class ThreadCyclicBarrier {


public static void main(String[] args) {
//创建障碍器
CyclicBarrier cyc=new CyclicBarrier(6,new MainTask());
new SubTask("a", cyc).start();
new SubTask("a1", cyc).start();
new SubTask("a2", cyc).start();
new SubTask("a3", cyc).start();
new SubTask("a4", cyc).start();
new SubTask("a5", cyc).start();

}
}


class MainTask implements Runnable{


@Override
public void run() {
// TODO Auto-generated method stub
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<9999;i++);//耗时操作
System.out.println("子任务已经执行完成"+name+"并通知障碍器已经完成");
try {
cb.await();//通知障碍器已经完成

} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
}

}



从执行结果可以看出,所有子任务完成的时候,主任务执行了,达到了控制的目标。



看一下子线程没有完成的情况-----:  设置线程数7 ,可实际线程数只有6,,发现主线程没有执行;



本文转载:CSDN博客