


Warum verhindert „flatMap()' von Java 8, dass „findFirst()' einen Kurzschluss verursacht?
Verzögerte Ausführung in Java 8-Streams: Die Interaktion von FlatMap() und FindFirst() verstehen
In Java-Stream-Operationen ist flatMap() Der Operator wird verwendet, um jedes Element im Stream in einen neuen Stream umzuwandeln, der dann zu einem einzigen Stream zusammengefasst wird. Wenn es jedoch in Verbindung mit der Terminaloperation findFirst() verwendet wird, zeigt es ein interessantes Verhalten, das Fragen zur verzögerten Ausführung aufwirft.
Im bereitgestellten Codeausschnitt erstellen wir zwei Streams: einen, der nur filter() verwendet, und einen der andere verwendet sowohl flatMap() als auch filter(). Während der erste Stream seine Ausführung sofort beendet und das erste Element zurückgibt, verarbeitet der zweite Stream den gesamten Stream weiter, obwohl er ein passendes Element findet.
Warum die Diskrepanz?
Der Schlüssel zum Verständnis dieser Diskrepanz liegt in der Art und Weise, wie diese Operationen umgesetzt werden. findFirst() ist eine Kurzschlussoperation, was bedeutet, dass die Ausführung gestoppt werden kann, sobald ein passendes Element gefunden wird. Bei Verwendung nach flatMap() wird die filter()-Operation jedoch für jedes Element des von flatMap() erzeugten Zwischenstreams ausgeführt, unabhängig davon, ob bereits eine Übereinstimmung gefunden wurde.
Dieses Verhalten ist darauf zurückzuführen eine Einschränkung in der JDK-8-Stream-Implementierung. Wenn flatMap() verwendet wird, ist der resultierende Stream nicht vollständig verzögert. Stattdessen „zieht“ es eifrig Elemente aus dem Quellstream und wendet die flatMap()-Transformation auf jedes Element an. Das bedeutet, dass selbst nachdem findFirst() eine Übereinstimmung findet und einen Abbruch auslöst, die Elemente, die bereits in den Zwischenstream gezogen wurden, weiterhin vom Filter()-Operator verarbeitet werden.
Auflösung in Java 10 und Backports
Die Java-Entwickler haben dieses Problem erkannt und es in Java 10 behoben und auf Java 8 zurückportiert. In diesen aktualisierten Versionen hat flatMap() wurde vollständig verzögert gemacht, sodass Kurzschlussoperationen wie filter() die Stream-Ausführung ordnungsgemäß beenden können, sobald eine Übereinstimmung gefunden wird.
Implikationen und Überlegungen
Während dies Das Problem wurde in späteren Versionen von Java behoben. Es unterstreicht, wie wichtig es ist, die verzögerten Ausführungseigenschaften von Stream-Operationen zu verstehen, insbesondere wenn flatMap() in Kombination mit Kurzschlüssen verwendet wird Operatoren.
Wenn eine verzögerte Ausführung für Ihre Anwendung von entscheidender Bedeutung ist, wird empfohlen, Java 10 oder eine neuere Version zu verwenden, in der dieses Problem behoben wurde. Alternativ können Sie Kurzschlüsse manuell in Ihren flatMap()-Transformationen implementieren, um eine ordnungsgemäße Beendigung sicherzustellen.
Das obige ist der detaillierte Inhalt vonWarum verhindert „flatMap()' von Java 8, dass „findFirst()' einen Kurzschluss verursacht?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Fehlerbehebung und Lösungen für die Sicherheitssoftware des Unternehmens, die dazu führt, dass einige Anwendungen nicht ordnungsgemäß funktionieren. Viele Unternehmen werden Sicherheitssoftware bereitstellen, um die interne Netzwerksicherheit zu gewährleisten. ...

Die Verarbeitung von Feldzuordnungen im Systemdocken stößt häufig auf ein schwieriges Problem bei der Durchführung von Systemdocken: So kartieren Sie die Schnittstellenfelder des Systems und ...

Bei Verwendung von MyBatis-Plus oder anderen ORM-Frameworks für Datenbankvorgänge müssen häufig Abfragebedingungen basierend auf dem Attributnamen der Entitätsklasse erstellt werden. Wenn Sie jedes Mal manuell ...

Lösungen zum Umwandeln von Namen in Zahlen zur Implementierung der Sortierung in vielen Anwendungsszenarien müssen Benutzer möglicherweise in Gruppen sortieren, insbesondere in einem ...

Beginnen Sie den Frühling mit der Intellijideaultimate -Version ...

Konvertierung von Java-Objekten und -Arrays: Eingehende Diskussion der Risiken und korrekten Methoden zur Konvertierung des Guss-Typs Viele Java-Anfänger werden auf die Umwandlung eines Objekts in ein Array stoßen ...

Detaillierte Erläuterung des Designs von SKU- und SPU-Tabellen auf E-Commerce-Plattformen In diesem Artikel werden die Datenbankdesignprobleme von SKU und SPU in E-Commerce-Plattformen erörtert, insbesondere wie man mit benutzerdefinierten Verkäufen umgeht ...

Wenn Sie TKMybatis für Datenbankabfragen verwenden, ist das Aufbau von Abfragebedingungen ein häufiges Problem. Dieser Artikel wird ...
