


Effizient gleichzeitige Verarbeitung von Stapelschnittstellenanforderungen: Stellen Sie sicher, dass die Reihenfolge der Ergebnisse konsistent ist
Gleichzeitige Aufrufe mehrerer Schnittstellen von Drittanbietern können die Effizienz bei der effizienten Bearbeitung großer Datenmengen erheblich verbessern. Eine einfache Multithread -Parallelität kann jedoch dazu führen, dass die Reihenfolge der Rückgabeergebnisse inkonsistent ist und der ursprünglichen Datenliste nicht entspricht. In diesem Artikel wird vorgestellt, wie dieses Problem mithilfe von Java CompletableFuture
gelöst werden kann, um sicherzustellen, dass die Interface -Aufrufergebnisse genau der ursprünglichen Datenreihenfolge übereinstimmen.
Frage:
Nehmen wir an, dass mehr als 1000 Schnittstellen von Drittanbietern gleichzeitig aufgerufen werden müssen, um die Ergebnisse zurückzugeben. Wenn mehrere Threads mit einer einfachen for
begonnen werden, kann die Reihenfolge der Schnittstellenaufrufe nicht garantiert werden und die Reihenfolge der Endergebnisse stimmt nicht mit der ursprünglichen Datenliste überein. Ein Beispielcode verwendet CompletableFuture.runAsync
, um asynchrone Aufgaben auszuführen, ignoriert jedoch die Erfassung von Ergebnissen und die Aufrechterhaltung der Sequenzialität.
Lösung:
Um sicherzustellen, dass die Reihenfolge der Ergebnisse mit der Originaldatenliste übereinstimmt, besteht der Schlüssel darin, CompletableFuture.supplyAsync
anstelle von CompletableFuture.runAsync
zu verwenden. supplyAsync
-Methode kann ein Ergebnis zurückgeben, während runAsync
keinen Wert zurückgibt. Geben Sie die Ergebnisse jeder Schnittstellenaufruf über supplyAsync
zurück und sammeln Sie die Ergebnisse in die Liste, indem Sie die Verarbeitung streamen, um sicherzustellen, dass die Reihenfolge der Ergebnisse mit der ursprünglichen Datenliste übereinstimmt.
Verbesserter Code:
public static void main (String [] args) { Liste<string> Datalist = new ArrayList (); // Originaldatenliste // ... Datalist initialisieren ... ExecutorService Executorservice = New ThreadPoolexecutor ( // Die Anzahl der Kern -Threads runchtime.getRuntime (). AFFORMPROCESSORS (), // Maximale Anzahl von Threads runTime.getRuntime (). AFFORMPROCESSORS () * 2, // Überlebenszeit von Thread 60L, TimeUnit.seconds, Neues LinkedBlockingQueue (), neuer threadpoolexecutor.calrrunspolicy ()); Liste <completablefuture> > futures = new ArrayList (); für (String -Daten: Datalist) { futures.add (komplettableFuture.supplyasync (() -> { logger.info ("Ausführung von asynchronem Thread starten->>" Daten); // Rufen Sie die Schnittstelle an und geben Sie Daten über // beurteilen Sie, ob Daten übereinstimmen, basierend auf dem Schnittstellenrückgabewert // Rückgabe des verarbeiteten Ergebnisrücklaufprozessdata (Daten); // Daten verarbeiten und das Ergebnis zurückgeben}, ExecutorService)); // Verwenden Sie einen benutzerdefinierten Threadpool} // Nach der Verarbeitung der Logik aller Anfragen abgeschlossen, komplettsableFuture.Allof (futures.toArray (neuer Vervollständigungsfuture [0])). Thenrun (() -> { Liste<string> Ergebnisse = Futures.stream () .MAP (Vervollständigbare Future :: Join) .Collect (sammel.tolist ()); logger.info ("Thread -Ausführung ist abgeschlossen: {}", json.tojonstring (Ergebnisse)); // rufen Sie an, um SMS}). Thenrun (() -> ExecutorService.shutdown ()); } // Methode zur Verarbeitung von Daten, ändern Sie private statische String processData (String -Daten) {{ // ... Schnittstellenanruf- und Datenverarbeitungslogik ... Daten zurückgeben "verarbeitetes Ergebnis"; }</string></completablefuture></string>
Durch das Speichern der Ergebnisse jeder CompletableFuture
in der futures
-Liste und das Sammeln der Ergebnisse am Ende unter Verwendung von futures.stream().map(CompletableFuture::join).collect(Collectors.toList())
ist die Ergebnisreihenfolge in Übereinstimmung mit der ursprünglichen Datenliste überein. CompletableFuture::join
-Methode blockiert, bis das Ergebnis CompletableFuture
erzielt wird. Dies löst effektiv das Problem inkonsistenter Ergebnisse im ursprünglichen Code.
Das obige ist der detaillierte Inhalt vonWie verwendete ich CompletenableFuture, um die Bestellkonsistenz der Ergebnissen der Stapelschnittstelle zu gewährleisten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

JVM implementiert die Wora-Merkmale von Java durch Bytecode-Interpretation, plattformunabhängige APIs und dynamische Klassenbelastung: 1. Bytecode wird als Maschinencode interpretiert, um einen plattformübergreifenden Betrieb sicherzustellen. 2. Unterschiede zwischen API -abstrakter Betriebssystem; 3. Die Klassen werden zur Laufzeit dynamisch geladen, um eine Konsistenz zu gewährleisten.

Die neueste Version von Java löst effektiv plattformspezifische Probleme durch JVM-Optimierung, Standardbibliotheksverbesserungen und Unterstützung von Drittanbietern. 1) JVM -Optimierung, wie der ZGC von Java11, verbessert die Leistung der Müllsammlung. 2) Standardbibliotheksverbesserungen wie das Modulsystem von Java9, das plattformbedingte Probleme reduziert. 3) Bibliotheken von Drittanbietern bieten plattformoptimierte Versionen wie OpenCV.

Der Bytecode -Überprüfungsprozess des JVM enthält vier wichtige Schritte: 1) Überprüfen Sie, ob das Klassendateiformat den Spezifikationen entspricht, 2) Überprüfen Sie die Gültigkeit und Korrektheit der Bytecode -Anweisungen, 3) die Datenflussanalyse durchführen, um die Sicherheitstypsicherheit zu gewährleisten, und 4) Ausgleich der gründlichen Überprüfung und Leistung der Verifizierung. Durch diese Schritte stellt die JVM sicher, dass nur sichere, korrekte Bytecode ausgeführt wird, wodurch die Integrität und Sicherheit des Programms geschützt wird.

Java'SplatformIndependenCealLowsApplicationStorunonanyoperatingsystemWithajvm.1) SinglecodeBase: WriteAndCompileonceForAllpatforms.2) EasyUpdates: UpdateByteCodeForsimultaneousDeployment.3) TestingEffizienz: testononePlatformForaNeunveralbehavior

Die Unabhängigkeit von Java wird durch Technologien wie JVM, JIT -Zusammenstellung, Standardisierung, Generika, Lambda -Ausdrücke und Projektpanama kontinuierlich verbessert. Seit den neunziger Jahren hat sich Java von Basic JVM zu hoher Leistung moderner JVM entwickelt, um die Konsistenz und Effizienz des Codes über verschiedene Plattformen hinweg zu gewährleisten.

Wie lindert Java plattformspezifische Probleme? Java implementiert plattformunabhängig über JVM- und Standardbibliotheken. 1) Bytecode und JVM verwenden, um die Unterschiede für das Betriebssystem abstrahieren; 2) Die Standardbibliothek bietet plattformübergreifende APIs wie Pfade der Klassenverarbeitungsdateien und die Codierung von Charset Class Processing. 3) Verwenden Sie Konfigurationsdateien und Multi-Plattform-Tests in tatsächlichen Projekten zur Optimierung und Debuggierung.

Java'SplatformIndependenceEnhancesMicroservicesArchitecture byFeringDeploymentFlexibilität, Konsistenz, Skalierbarkeit und Portabilität.1) EinsatzFlexibilitätsmarkroservicestorunonanyplatformwithajvm.2) konsistenzacrossservicessimplimplimplifiesDevention und

Graalvm verbessert die Unabhängigkeit der Java-Plattform auf drei Arten: 1. Cross-Sprach-Interoperabilität und ermöglicht es Java, nahtlos mit anderen Sprachen zusammenzuarbeiten; 2. Unabhängige Laufzeitumgebung, kompilieren Sie Java -Programme in lokale ausführbare Dateien über GraalvmnativeImage; 3. Die Leistungsoptimierung generiert Graal Compiler einen effizienten Maschinencode, um die Leistung und Konsistenz von Java -Programmen zu verbessern.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Dreamweaver Mac
Visuelle Webentwicklungstools
