Iterieren von Streams mit Indizes in Java 8
In Java 8 bieten Streams eine leistungsstarke Möglichkeit, Sammlungen von Elementen zu verarbeiten. Allerdings kann die Iteration über einen Stream beim Zugriff auf Indizes eine Herausforderung sein.
Das bereitgestellte Code-Snippet zeigt eine ausgefeilte Lösung mit zip und SimpleEntry zum Koppeln von Indizes und Stream-Elementen. Gibt es jedoch einen prägnanteren Ansatz?
Zum Glück ja. Sie können mit einem Strom von Indizes beginnen und basierend auf dem Index filtern, indem Sie ihn mit der Länge des entsprechenden Elements vergleichen. Hier ist ein Beispiel:
String[] names = {"Sam", "Pamela", "Dave", "Pascal", "Erik"}; IntStream.range(0, names.length) .filter(i -> names[i].length() <= i) .mapToObj(i -> names[i]) .collect(Collectors.toList());
Alternativer Ansatz
Alternativ können Sie einen Ad-hoc-Zähler mithilfe eines veränderlichen Objekts wie AtomicInteger verwalten. Diese Methode sollte jedoch nicht bei parallelen Streams verwendet werden, da sie aufgrund der Verarbeitung außerhalb der Reihenfolge zu falschen Ergebnissen führen kann. Ein Beispiel:
AtomicInteger index = new AtomicInteger(); List<String> list = Arrays.stream(names) .filter(n -> n.length() <= index.incrementAndGet()) .collect(Collectors.toList());
Das obige ist der detaillierte Inhalt vonWie kann man Java 8-Streams effizient mit Indizes iterieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!