package endual;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
/**
* 犹如倒计时的计数器,调用countDownLatch对象的countDown方法就将计数器
* 减去1,当计数器到到0的时候,那么所有等待多种等待的开始执行。这直接通过代码来实现
* CountDownLathchd的作用,这样就更可以理解这个意思了的
* @author endual
*
*/
public class CountDownLatchApp {
public static void main(String[] args) {
ExecutorService es = Executors.newCachedThreadPool() ; //创建了线程池,要多少线程就有多少线程的
final CountDownLatch cdl = new CountDownLatch(10) ;
for (int i=0; i < 10; i++) {
Runnable runn = new Runnable() {
public void run() {
cdl.countDown() ;//每次调用减去1
try {
cdl.await() ; //一定要用这个表示等待的,要不就没有用了,这个还比是起跑线了
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName());
}
};
System.out.println("x" + cdl.getCount() ) ;
es.execute(runn) ;
}
}
}
注意要用await()方法表示的等待哦,要不是没用的。