Optimale Implementierung für das Warten auf einer Liste von Futures
Asynchrone Programmierung bietet Vorteile wie eine erhöhte Reaktionsfähigkeit und eine effiziente Ressourcennutzung. Die gleichzeitige Verwaltung mehrerer Futures kann jedoch zu Herausforderungen bei der Koordinierung ihres Abschlusses und der effizienten Behandlung von Ausnahmen führen. In diesem Artikel wird eine Lösung für das Problem untersucht, zu warten, bis alle Futures in einer Liste abgeschlossen sind oder in einem von ihnen eine Ausnahme auftritt.
Der unkomplizierte Ansatz besteht darin, jeden Future einzeln mit Future.get() zu prüfen. Bei großen Listen wird diese Methode jedoch ineffizient, da auf den Abschluss aller Futures gewartet werden muss, selbst wenn in einer früheren Aufgabe ein Fehler auftritt.
Eine alternative Lösung besteht in der Verwendung eines CompletionService. Dieser Dienst stellt eine blockierende take()-Methode bereit, die es dem Aufrufer ermöglicht, abgeschlossene Futures zu empfangen, sobald diese verfügbar sind. Gleichzeitig ermöglicht es den Abbruch laufender Aufgaben im Fehlerfall.
Betrachten Sie die folgende Implementierung:
<code class="java">Executor executor = Executors.newFixedThreadPool(4); CompletionService<SomeResult> completionService = new ExecutorCompletionService<SomeResult>(executor); // Submit 4 tasks for (int i = 0; i < 4; i++) { completionService.submit(new Callable<SomeResult>() { public SomeResult call() { ... // Task logic return result; } }); } int received = 0; boolean errors = false; // Monitor future completion and errors while (received < 4 && !errors) { Future<SomeResult> resultFuture = completionService.take(); // Blocks if no futures available try { SomeResult result = resultFuture.get(); received++; ... // Process result } catch (Exception e) { // Log error errors = true; } }</code>
In dieser Implementierung empfängt der CompletionService abgeschlossene Futures über seine take()-Methode . Wenn eine Aufgabe eine Ausnahme auslöst, wird das Fehlerflag auf „true“ gesetzt und die Schleife wird beendet. Dieser Ansatz reduziert die Wartezeit für nachfolgende Aufgaben erheblich, was zu einer effizienteren Ausnahmebehandlung führt.
Auf Wunsch können Sie diese Lösung erweitern, indem Sie bei Auftreten eines Fehlers alle ausstehenden Aufgaben abbrechen und so sicherstellen, dass Ressourcen umgehend freigegeben werden.
Das obige ist der detaillierte Inhalt vonWie kann man effizient auf mehrere Futures warten und Ausnahmen behandeln: CompletionService vs. einzelne Future-Checks?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!