首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

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

2012-10-09 
几种等待并发线程全部完成的方法学习到如下几种方法:1、对于单个的线程,可以采用Future.get()的方法,任务执

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

学习到如下几种方法:

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();

???

热点排行