加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 如何在继续之前等待所有callables完成执行?

发布时间:2020-12-15 05:00:41 所属栏目:Java 来源:网络整理
导读:我有以下代码哈希: public class MyCallable implements CallableLong { @Override public Long call() throws Exception { // Do stuff... }}public class MyController { private ExecutorService executor = Executos.newCachedTreadPool(); public Long
我有以下代码哈希:

public class MyCallable implements Callable<Long> {
    @Override
    public Long call() throws Exception {
        // Do stuff...
    }
}

public class MyController {
    private ExecutorService executor = Executos.newCachedTreadPool();

    public Long concurrentDoStuff() {
        List<MyCallable> workers = makeWorkers();

        List<Long> allResults = new ArrayList<Long>();
        for(MyCallable worker : workers) {
            Future<Long> workerResults = executor.submit(worker);

            try {
                allResults.add(workerResults.get());
            } catch(InterruptedException ie) {
                // Handle...
            } catch(ExecutionException ee) {
                // Handle...
            }
        }

        // Question: how do I pause here and wait for all workers to finish?
    }
}

在for循环之后,我想等待所有工人完成任务以继续进行.什么是最好/最安全/最有效的方法?提前致谢!

解决方法

您必须使用shutDown关闭Executor,然后等待所有作业都使用awaitTermination进行处理.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读