Java에서 futures 작업을 수행할 때 미래 작업 목록이 완료될 때까지 기다려야 할 수도 있습니다. 발생하는 예외를 처리하는 동안. 이에 대한 간단한 접근 방식은 각 future를 순차적으로 기다리고 잠재적인 예외를 확인하는 것입니다. 그러나 이 접근 방식은 목록 앞부분에서 예외가 발생하면 후속 작업이 불필요하게 계속 대기하게 되므로 효율성 문제가 발생합니다.
이 문제를 해결하기 위해 CompletionService 클래스를 활용하는 대체 솔루션이 있습니다. CompletionService는 가능한 미래를 수신하고 예외가 발생할 경우 조기 종료를 허용합니다.
이 접근 방식을 구현하는 방법의 예는 다음과 같습니다.
<code class="java">Executor executor = Executors.newFixedThreadPool(4); CompletionService<SomeResult> completionService = new ExecutorCompletionService<>(executor); // 4 tasks for (int i = 0; i < 4; i++) { completionService.submit(new Callable<SomeResult>() { public SomeResult call() { // ... task implementation return result; } }); } int received = 0; boolean errors = false; while (received < 4 && !errors) { Future<SomeResult> resultFuture = completionService.take(); // Blocks if none available try { SomeResult result = resultFuture.get(); received++; // ... do something with the result } catch (Exception e) { // Log the exception errors = true; } } // Potentially consider canceling any still running tasks if errors occurred</code>
CompletionService 활용 , 예외를 신속하게 처리하는 동시에 향후 작업이 완료될 때까지 효율적으로 기다릴 수 있습니다.
위 내용은 Java에서 Future 목록을 효율적으로 관리하고 예외를 처리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!