2
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()方法,但我不知道该怎么做。希望您能帮助解决这个问题。

谢谢你的时间。

4

1 回答 1

0

如果您需要一组线程在某个时候相遇 - 尝试使用“障碍”模式。

Java SE 有它的实现:java.util.concurrent.CyclicBarrier

来自 docs :一种同步辅助工具,它允许一组线程相互等待以达到共同的障碍点。CyclicBarriers 在涉及固定大小的线程组的程序中很有用,这些线程组必须偶尔相互等待。屏障被称为循环的,因为它可以在等待线程被释放后重新使用。

CyclicBarrier 支持一个可选的 Runnable 命令,该命令在每个屏障点运行一次,在队伍中的最后一个线程到达之后,但在任何线程被释放之前。此屏障操作对于在任何一方继续之前更新共享状态很有用。

http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/CyclicBarrier.html

于 2013-09-26T10:40:47.167 回答