ExecutorService exec = Executors.newFixedThreadPool(8);
List<Future<Object>> results = new ArrayList<Future<Object>>();
// submit tasks
for(int i = 0; i < 8; i++) {
results.add(exec.submit(new ThreadTask()));
}
...
// stop the pool from accepting new tasks
exec.shutdown();
// wait for results
for(Future<Object> result: results) {
Object obj = result.get();
}
class ThreadTask implements Callable<Object> {
public Object call() {
// execute download
...
return result;
}
}
上面的代码没有显示我预期的结果。更详细地说,我正在为android做一个下载管理器。这些线程用于分段下载文件。由于每个细分可能需要不同的持续时间来下载,我认为这就是问题所在。
然后我尝试在方法中使用一个简单的数字返回。然后线程开始给出预期的结果。
作为一个解决方案,我想到实现一个方法来等待所有线程完成执行。在上面的代码中,我如何等待所有线程完成他们的工作?我想我必须使用wait()
方法,但我不知道该怎么做。希望你可以帮忙弄明白。
感谢您的时间。
答案 0 :(得分:0)
如果您需要在某些时候遇到一组线程 - 请尝试使用“屏障”模式。
Java SE有它的实现:java.util.concurrent.CyclicBarrier
来自docs:一种同步辅助工具,允许一组线程全部等待彼此到达公共障碍点。 CyclicBarriers在涉及固定大小的线程方的程序中很有用,这些线程必须偶尔等待彼此。屏障称为循环,因为它可以在等待线程释放后重新使用。
CyclicBarrier支持可选的Runnable命令,该命令在每个障碍点运行一次,在聚会中的最后一个线程到达之后,但在释放任何线程之前。在任何一方继续之前,此屏障操作对于更新共享状态非常有用。
http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/CyclicBarrier.html