


Warum ist filter() nach flatMap() in Java Streams nicht „komplett“ faul?
In Java 8 Streams sind Zwischenoperationen wie filter() und flatMap() sind lazy, was bedeutet, dass sie erst ausgeführt werden, wenn eine Terminaloperation wie findFirst() aufgerufen wird. Wenn jedoch filter() auf flatMap() folgt, wird diese Trägheit nicht vollständig erkannt, was zu unerwartetem Verhalten führt.
Betrachten Sie dieses Codebeispiel:
Stream.of(1, 2, 3) .filter(i -> { System.out.println(i); return true; }) .findFirst() .get();
Die Ausgabe zeigt, dass nur das erste Das Element wird gedruckt, was darauf hinweist, dass filter() faul ist und kurzschließt, wenn die Bedingung erfüllt ist. Im Gegensatz dazu:
Stream.of(1, 2, 3) .flatMap(i -> Stream.of(i - 1, i, i + 1)) .flatMap(i -> Stream.of(i - 1, i, i + 1)) .filter(i -> { System.out.println(i); return true; }) .findFirst() .get();
Überraschenderweise sind alle Elemente gedruckt. Auch wenn filter() seine Bedingung sofort erfüllt, verarbeitet es weiterhin nachfolgende Elemente des Streams.
Der Grund
Dieses Verhalten ist auf die Java Streams-Implementierung zurückzuführen. Nach flatMap() enthält der Stream nicht mehr die ursprünglichen Elemente. Stattdessen enthält es eine Folge abgeflachter Elemente, die von flatMap() generiert wurden. Wenn filter() folgt, bearbeitet es diese abgeflachten Elemente, nicht den ursprünglichen Stream.
Die Implementierung von forEachWithCancel(), die in findFirst() verwendet wird, ruft kontinuierlich tryAdvance() auf dem Spliterator bis zur Senke auf fordert eine Stornierung an oder der Spliterator ist erschöpft. Im Fall von flatMap() schreitet der Spliterator ohne Möglichkeit einer vorzeitigen Beendigung weiter voran, selbst wenn filter() bereits eine Übereinstimmung gefunden hat.
Fix
Dieses Problem wurde in Java 10 behoben und auf Java 8 zurückportiert. Die Implementierung ermöglicht jetzt eine vorzeitige Beendigung in flatMap(), wenn eine Kurzschlussoperation wie filter() stattfindet verwendet.
Fazit
Verständlicherweise kann es verwirrend sein, warum sich filter() nach flatMap() so verhält, als ob es nicht faul wäre. Die zugrunde liegende Java Streams-Implementierung diktiert dieses Verhalten, das später in Java 10 behoben und auf Java 8 zurückportiert wurde. Dieses Verständnis ist entscheidend für die effiziente Handhabung solcher Szenarien.
Das obige ist der detaillierte Inhalt vonWarum scheint „filter()' nach „flatMap()' in Java Streams nicht faul zu sein?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Dieser Artikel analysiert 2025 die vier besten JavaScript -Frameworks (React, Angular, Vue, Svelte) und verglichen ihre Leistung, Skalierbarkeit und Zukunftsaussichten. Während alle aufgrund starker Gemeinschaften und Ökosysteme dominant bleiben, sind ihr relatives Popul

Mit der Klassenbelastung von Java wird das Laden, Verknüpfen und Initialisieren von Klassen mithilfe eines hierarchischen Systems mit Bootstrap-, Erweiterungs- und Anwendungsklassenloadern umfasst. Das übergeordnete Delegationsmodell stellt sicher

In dem Artikel wird in der Implementierung von mehrstufigem Caching in Java mithilfe von Koffein- und Guava-Cache zur Verbesserung der Anwendungsleistung erläutert. Es deckt die Einrichtungs-, Integrations- und Leistungsvorteile sowie die Bestrafung des Konfigurations- und Räumungsrichtlinienmanagements ab

Dieser Artikel befasst sich mit der Verwundbarkeit von CVE-2022-1471 in Snakeyaml, einem kritischen Fehler, der die Ausführung von Remote-Code ermöglicht. Es wird beschrieben

Node.js 20 verbessert die Leistung durch V8 -Motorverbesserungen erheblich, insbesondere durch schnellere Müllsammlung und E/A. Zu den neuen Funktionen gehören eine bessere Support von WebAssembly und raffinierte Debugging -Tools, die Produktivität der Entwickler und die Anwendungsgeschwindigkeit.

Iceberg, ein offenes Tabellenformat für große analytische Datensätze, verbessert die Leistung und Skalierbarkeit von Data Lake. Es befasst sich mit Einschränkungen von Parquet/ORC durch internes Metadatenmanagement und ermöglicht eine effiziente Schemaentwicklung, Zeitreisen, gleichzeitiger W

In diesem Artikel wird die Integration der funktionalen Programmierung in Java unter Verwendung von Lambda -Ausdrücken, Streams -API, Methodenreferenzen und optional untersucht. Es zeigt Vorteile wie eine verbesserte Lesbarkeit der Code und die Wartbarkeit durch SUKTIVE UND VERUSNAHMETALITÄT

In dem Artikel werden Maven und Gradle für Java -Projektmanagement, Aufbau von Automatisierung und Abhängigkeitslösung erörtert, die ihre Ansätze und Optimierungsstrategien vergleichen.


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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

DVWA
Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung
