Maison > Java > javaDidacticiel > Comment générer efficacement des paires successives à partir d'un flux d'éléments ?

Comment générer efficacement des paires successives à partir d'un flux d'éléments ?

Susan Sarandon
Libérer: 2024-12-15 12:54:25
original
867 Les gens l'ont consulté

How Can We Efficiently Generate Successive Pairs from a Stream of Elements?

Paires successives d'un flux

Étant donné un flux de primitives ou d'objets comme {0, 1, 2, 3, 4}, comment pouvons-nous le transformer sans effort en paires successives, comme illustré ci-dessous ?

{new Pair(0, 1), new Pair(1, 2), new Pair(2, 3), new Pair(3, 4)}
Copier après la connexion

Plonger dans le Solution

Bien que la bibliothèque de flux Java 8 excelle dans la division des flux en morceaux gérables pour un traitement parallèle, elle pose des défis pour les étapes de pipeline avec état. Récupérer l'index de l'élément de flux actuel ou accéder aux éléments adjacents sont des limitations notables.

Pour contourner ces contraintes, nous employons souvent une technique qui implique d'exploiter les index pour piloter le flux. Voici un aperçu de la façon dont nous pouvons générer des paires avec cette approche :

Extrait de code :

    IntStream.range(1, arrayList.size())
             .mapToObj(i -> new Pair(arrayList.get(i-1), arrayList.get(i)))
             .forEach(System.out::println);
Copier après la connexion

Explication de la solution :

Dans cet exemple, nous parcourons ArrayList avec des index commençant à 1, garantissant que pour chaque index i, nous pouvons accéder à la fois à arrayList.get(i-1) et à arrayList.get(i). Le nœud du code est la fonction mapToObj, qui convertit chaque index en une paire contenant les éléments adjacents.

Limitations et extensions :

Bien que cette approche soit efficace pour flux finis stockés dans une collection à accès aléatoire, cela ne s'applique pas aux flux infinis. Cependant, le pipeline peut être exécuté en parallèle, offrant ainsi des avantages en termes de performances.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal