I have a method which returns a List
of futures
List<Future<O>> futures = getFutures();
Now I want to wait until either all futures are done processing successfully or any of the tasks whose output is returned by a future throws an exception. Even if one task throws an exception, there is no point in waiting for the other futures.
Simple approach would be to
wait() {
For(Future f : futures) {
try {
f.get();
} catch(Exception e) {
//TODO catch specific exception
// this future threw exception , means somone could not do its task
return;
}
}
}
But the problem here is if, for example, the 4th future throws an exception, then I will wait unnecessarily for the first 3 futures to be available.
How to solve this? Will count down latch help in any way? I'm unable to use Future isDone
because the java doc says
boolean isDone()
Returns true if this task completed. Completion may be due to normal termination, an exception, or cancellation -- in all of these cases, this method will return true.
ExecutionService
for every "batch" of tasks, submit them to it, then immediately shut down the service and useawaitTermination()
on it I suppose. – CollinsworthCountDownLatch
if you wrapped the body of all your futures in atry..finally
to make sure the latch gets decremented as well. – Collinsworthtry..finally
, nottry..catch
. The exception will be rethrown andFuture.get()
would throw. It'd just make sure the latch gets counted down. That said, the suggestions to useCompletionService
are clearly superior. – Collinsworth