Heim > Java > javaLernprogramm > Hauptteil

Wie kann CompletionService verwendet werden, um das Warten auf eine Liste von Futures zu optimieren und Ausnahmen effizient zu behandeln?

Patricia Arquette
Freigeben: 2024-10-25 19:58:29
Original
934 Leute haben es durchsucht

How can CompletionService be used to optimize waiting for a list of futures and handle exceptions efficiently?

Optimieren der Wartezeit auf zukünftige Listen mit CompletionService

Bei der Arbeit mit einer Liste von Futures ist es wichtig, effizient auf deren Abschluss zu warten oder Ausnahmen zu behandeln Vermeiden Sie unnötige Verzögerungen.

Angenommen, Sie haben die folgende Methode, die eine Liste von Futures zurückgibt:

List<Future<O>> futures = getFutures();
Nach dem Login kopieren

Um auf den Abschluss zu warten oder Ausnahmen abzufangen, könnte ein naiver Ansatz sein:

wait() {
  for(Future f : futures) {
    try {
      f.get();
    } catch(Exception e) {
       //Specific exception handling
       //Exception in a future, stop waiting
       return;
    }
  }
}
Nach dem Login kopieren

Dieser Ansatz wartet jedoch auf jede Zukunft, unabhängig von Ausnahmen in früheren Futures.

Eine Lösung besteht darin, einen CompletionService einzusetzen, um Futures zu erhalten, sobald sie verfügbar sind. Wenn eine Ausnahme auftritt, können Sie andere Aufgaben abbrechen:

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

//Submit tasks
for(int i = 0; i < 4; i++) {
  completionService.submit(() -> {
    ...
    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++;
    ... //Process result
  } catch(Exception e) {
    //Log and set error flag
    errors = true;
  }
}
Nach dem Login kopieren

Bei diesem Ansatz werden Aufgaben an den Ausführenden übermittelt und abgeschlossene Aufgaben werden über den Abschlussdienst empfangen. Wenn in einer empfangenen Aufgabe eine Ausnahme auftritt, wird die while-Schleife beendet und Sie können alle verbleibenden Aufgaben mit der Methode „shutdownNow()“ des Executors abbrechen.

Das obige ist der detaillierte Inhalt vonWie kann CompletionService verwendet werden, um das Warten auf eine Liste von Futures zu optimieren und Ausnahmen effizient zu behandeln?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!