读书人

几种等候并发线程全部完成的方法

发布时间: 2012-10-09 10:21:45 作者: rapoo

几种等待并发线程全部完成的方法

学习到如下几种方法:

1、对于单个的线程,可以采用Future.get()的方法,任务执行完毕后才能拿到结果。

2、对于多个线程,可以采用executor.awaitTemination()的方法,伪代码如下所示:

??? for(int i = 0;i < n;i++){

?????????? executor.execute(task(i));

??? }

??? executor.shutdown();

??? executor.awaitTemination(Long.MAX_VALUE,TimeUnit.SECONDS);

3、可以采用闭锁,制造阀门效应,伪代码如下所示:

??? #主线程执行

??? CountDonwLatch done = new CountDownLatch(n);

??? for(int i = 0;i < n;i++){

?????????? executor.execute(task(i));

??? }

??? done.await();

???

??? #多线程任务中执行

??? doTask(i);

??? done.countDown();

???

读书人网 >编程

热点推荐