그래서 호출 가능한 작업 중 일부는 invokeAll을 사용하여 ExecutorService에 제출하는의 중단에 민감한 입니다. 다른 메소드에서 5 초가 지난 후 executorService.shutdownNow를 호출 한 후 true를 반환하는 awaitTermination을 호출하므로 모두 양호한 것처럼 보입니다. 문제는 집행자가 종료되지 않는다는 것입니다.ExecutorService.invokeAll 및 종료
로깅으로 인해 각 작업이 완료되었다는 것을 알고 있습니다. 그럼에도 f.get 아직도 블록 내가 실행 프로그램 스레드들의 수와 동일하다 invokeAll을 :
다음 코드 AbstractExecutorService + 일부 로깅로부터 얻어진다.
@Override
public <T> List<Future<T>> invokeAll(Collection<? extends Callable<T>> tasks) throws InterruptedException {
if (tasks == null) throw new NullPointerException();
ArrayList<Future<T>> futures = new ArrayList<Future<T>>(tasks.size());
boolean done = false;
try {
List<Callable<T>> list = new ArrayList<Callable<T>>();
for (Callable<T> t : tasks) {
list.add(t);
RunnableFuture<T> f = newTaskFor(t);
futures.add(f);
execute(f);
}
for (int i = 0, size = futures.size(); i < size; i++) {
Future<T> f = futures.get(i);
if (!f.isDone()) {
log.info("Future %s is not done!. Task %s", i, list.get(i));
try {
log.info("Get from future %s", i);
// NEXT LINE BLOCKS FOR i= NUMBER OF THREADS
f.get();
log.info("Got result from future %s", i);
} catch (CancellationException ignore) {
} catch (ExecutionException ignore) {
}
}
}
log.info("Obtained all!");
done = true;
return futures;
} finally {
if (!done) for (int i = 0, size = futures.size(); i < size; i++)
futures.get(i).cancel(true);
}
}
종료와 함께 invokeAll을 사용하지 않겠습니까? 나는 그들이 같은 수업을 듣고있는 것 같아. 왜 i가 executor의 스레드의 수인 경우에만 차단됩니까?