如何解决相当于ThreadPool for Java中的进程
我正在从Java中的类(使用Linux平台上的作业调度程序调用该类)开始一些外部进程(使用Process类)。
我的问题是,作业调度程序会在主类调用最后一个进程后立即杀死所有内容。
所以我正在寻找类似ThreadPoolExecutor / CountDownLatch的方法来管理这些进程,并使主类在退出之前等待它们完成。
如果我在循环中调用 process.waitFor(),它们将按顺序启动,这是我不希望的。
我需要将这些进程放入线程中并使用真正的ThreadPoolExecutor还是有更漂亮/更简单的方法?
解决方法
与其在启动进程的同一循环中调用process.waitFor()
,而是在另一个循环中调用它:
List<Process> processes = new ArrayList<>();
// Start subprocesses and add them to the process list
for (...) {
processes.add(processBuilder.start());
}
// Wait for them to complete
for (Process p : processes) {
p.waitFor();
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。