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
Susan Sarandonoriginal
2024-12-15 12:54:25872parcourir

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)}

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);

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!

Déclaration:
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