首页 > Java > java教程 > 在继续执行 ExecutorService 之前如何确保所有任务都已完成?

在继续执行 ExecutorService 之前如何确保所有任务都已完成?

Linda Hamilton
发布: 2024-11-28 08:14:13
原创
879 人浏览过

How Can I Ensure All Tasks Complete Before Proceeding with an ExecutorService?

ExecutorService - 等待任务完成的解决方案

当处理大量需要并发执行的计算任务时,它是重要的是要有一个机制来等待所有任务完成。这确保只有在所有任务完成后才能执行后续操作。

在您的示例中,您尝试使用 ExecutorService.wait() 来实现此目的,您遇到了 IllegalMonitorStateException。出现此错误是因为 wait() 应该在等待对象的固有锁时使用,这在这种情况下不适用。

最简单的解决方案是利用 ExecutorService.invokeAll()。此方法采用 Callable 任务的集合,并行执行它们,并返回 Future 对象的列表。每个 Future 代表特定任务的结果。默认情况下,invokeAll() 将阻塞,直到所有任务完成后才返回 Future 对象列表。

以下是修改代码的方法:

ExecutorService es = Executors.newFixedThreadPool(2);
List<Callable<Object>> tasks = new ArrayList<>();

for (DataTable singleTable : uniquePhrases) {
    tasks.add(Executors.callable(new ComputeDTask(singleTable)));
}

List<Future<Object>> results = es.invokeAll(tasks);
登录后复制

在此更新的代码中,ExecutorService .invokeAll() 将等待所有任务完成,让您可以自信地继续后续操作。

以上是在继续执行 ExecutorService 之前如何确保所有任务都已完成?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板