API Stream de Java 8 réécrite sur les itérateurs pour Java 7 et versions antérieures.
Supplier
, Function
, Consumer
, etc.);Stream
/ IntStream
/ LongStream
/ DoubleStream
(sans traitement parallèle, mais avec diverses méthodes supplémentaires et avec des opérateurs personnalisés) ;Optional
/ OptionalBoolean
/ OptionalInt
/ OptionalLong
/ OptionalDouble
;Exceptional
- manière fonctionnelle de gérer les exceptions ;Objects
de Java 7. Stream . of ( /* array | list | set | map | anything based on Iterator/Iterable interface */ )
. filter (..)
. map (..)
...
. sorted ()
. forEach (..);
Stream . of ( value1 , value2 , value3 )...
IntStream . range ( 0 , 10 )...
Exemple de projet : https://github.com/aNNiMON/Android-Java-8-Stream-Example
Contrairement aux flux Java 8, Lightweight-Stream-API offre la possibilité d'appliquer des opérateurs personnalisés.
Stream . of (...)
. custom ( new Reverse <>())
. forEach (...);
public final class Reverse < T > implements UnaryOperator < Stream < T >> {
@ Override
public Stream < T > apply ( Stream < T > stream ) {
final Iterator <? extends T > iterator = stream . getIterator ();
final ArrayDeque < T > deque = new ArrayDeque < T >();
while ( iterator . hasNext ()) {
deque . addFirst ( iterator . next ());
}
return Stream . of ( deque . iterator ());
}
}
Vous pouvez trouver plus d’exemples ici.
En plus des opérateurs Java 8 Stream rétroportés, la bibliothèque fournit :
filterNot
- opérateur filter
annulé
// Java 8
stream . filter ((( Predicate < String >) String :: isEmpty ). negate ())
// LSA
stream . filterNot ( String :: isEmpty )
select
- filtre les instances de la classe donnée
// Java 8
stream . filter ( Integer . class :: isInstance )
// LSA
stream . select ( Integer . class )
withoutNulls
- filtre uniquement les éléments non nuls
Stream . of ( "a" , null , "c" , "d" , null )
. withoutNulls () // [a, c, d]
sortBy
- trie par fonction d'extracteur
// Java 8
stream . sorted ( Comparator . comparing ( Person :: getName ))
// LSA
stream . sortBy ( Person :: getName )
groupBy
- groupes par fonction d'extracteur
// Java 8
stream . collect ( Collectors . groupingBy ( Person :: getName )). entrySet (). stream ()
// LSA
stream . groupBy ( Person :: getName )
chunkBy
- partitions le flux trié par fonction de classificateur
Stream . of ( "a" , "b" , "cd" , "ef" , "gh" , "ij" , "klmnn" )
. chunkBy ( String :: length ) // [[a, b], [cd, ef, gh, ij], [klmnn]]
sample
- émet tous les n-ièmes éléments
Stream . rangeClosed ( 0 , 10 )
. sample ( 2 ) // [0, 2, 4, 6, 8, 10]
slidingWindow
- les partitions sont diffusées en liste de taille fixe et glissent sur les éléments
Stream . rangeClosed ( 0 , 10 )
. slidingWindow ( 4 , 6 ) // [[0, 1, 2, 3], [6, 7, 8, 9]]
takeWhile
/ dropWhile
- introduit dans Java 9, limite/ignore le flux par fonction de prédicat
Stream . of ( "a" , "b" , "cd" , "ef" , "g" )
. takeWhile ( s -> s . length () == 1 ) // [a, b]
Stream . of ( "a" , "b" , "cd" , "ef" , "g" )
. dropWhile ( s -> s . length () == 1 ) // [cd, ef, g]
scan
- applique de manière itérative la fonction d'accumulation et renvoie Stream
IntStream . range ( 1 , 6 )
. scan (( a , b ) -> a + b ) // [1, 3, 6, 10, 15]
indexed
- ajoute un index à chaque élément, le résultat est IntPair
Stream . of ( "a" , "b" , "c" )
. indexed () // [(0 : "a"), (1 : "b"), (2 : "c")]
filterIndexed
/ mapIndexed
/ takeWhileIndexed
/ takeUntilIndexed
/ dropWhileIndexed
/ reduceIndexed
/ forEachIndexed
- spécialisation indexée des opérateurs
Stream . of ( "a" , "b" , "c" )
. mapIndexed (( i , s ) -> s + Integer . toString ( i )) // [a0, b1, c2]
Fini les try/catch laids dans les expressions lambda.
// Java 8
stream . map ( file -> {
try {
return new FileInputStream ( file );
} catch ( IOException ioe ) {
return null ;
}
})
// LSA
stream . map ( Function . Util . safe ( FileInputStream :: new ))
Téléchargez la dernière version ou récupérez-la via Maven :
< dependency >
< groupId >com.annimon</ groupId >
< artifactId >stream</ artifactId >
< version >1.2.2</ version >
</ dependency >
ou Gradle :
dependencies {
.. .
implementation ' com.annimon:stream:1.2.2 '
.. .
}
ou utilisez les dernières fonctionnalités non publiées avec JitPack.
Version également incluse pour Java ME . Commander la branche Javame.