Home  >  Article  >  Java  >  How to Efficiently Wait for a List of Futures and Handle Exceptions?

How to Efficiently Wait for a List of Futures and Handle Exceptions?

Linda Hamilton
Linda HamiltonOriginal
2024-10-26 00:48:28889browse

How to Efficiently Wait for a List of Futures and Handle Exceptions?

Waiting Efficiently on a List of Futures

When dealing with a list of futures, the goal is to wait until completion or the occurrence of an exception in any future. A naive approach involving individual calls to f.get() can lead to unnecessary waiting if an exception occurs early on.

Avoiding Unnecessary Waiting with CompletionService

To address this issue, the CompletionService class comes into play. It allows asynchronous tasks to be executed and their results to be retrieved in a thread-safe manner as they become available. Here's how to use it:

<code class="java">Executor executor = Executors.newFixedThreadPool(4);
CompletionService<SomeResult> completionService = new ExecutorCompletionService<>(executor);

// Submit tasks to the service
for (int i = 0; i < 4; i++) {
    completionService.submit(new Callable<SomeResult>() {
        @Override
        public SomeResult call() {
            // Task logic here
            return result;
        }
    });
}

int received = 0;
boolean errors = false;

// Loop until all tasks are complete or an error occurs
while (received < 4 && !errors) {
    Future<SomeResult> resultFuture = completionService.take(); // Blocks if nothing available
    try {
        SomeResult result = resultFuture.get();
        received++;
        // Process result here
    } catch (Exception e) {
        // Log error
        errors = true;
    }
}

// Consider canceling remaining tasks if an error occurred</code>

By using the CompletionService approach, you can monitor the completion of tasks in real-time and halt further processing if an error occurs, thus avoiding unnecessary waiting.

The above is the detailed content of How to Efficiently Wait for a List of Futures and Handle Exceptions?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn