Stream API desde Java 8 reescrito en iteradores para Java 7 y versiones anteriores.
Supplier
, Function
, Consumer
, etc.);Stream
/ IntStream
/ LongStream
/ DoubleStream
(sin procesamiento paralelo, pero con una variedad de métodos adicionales y con operadores personalizados);Optional
/ OptionalBoolean
/ OptionalInt
/ OptionalLong
/ OptionalDouble
;Exceptional
: forma funcional de abordar excepciones;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 )...
Proyecto de ejemplo: https://github.com/aNNiMON/Android-Java-8-Stream-Example
A diferencia de las secuencias de Java 8, Lightweight-Stream-API brinda la capacidad de aplicar operadores personalizados.
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 ());
}
}
Puedes encontrar más ejemplos aquí.
Además de los operadores Java 8 Stream compatibles, la biblioteca proporciona:
filterNot
- operador filter
negado
// Java 8
stream . filter ((( Predicate < String >) String :: isEmpty ). negate ())
// LSA
stream . filterNot ( String :: isEmpty )
select
- filtra instancias de la clase dada
// Java 8
stream . filter ( Integer . class :: isInstance )
// LSA
stream . select ( Integer . class )
withoutNulls
: filtra solo elementos no nulos
Stream . of ( "a" , null , "c" , "d" , null )
. withoutNulls () // [a, c, d]
sortBy
: ordena por función extractora
// Java 8
stream . sorted ( Comparator . comparing ( Person :: getName ))
// LSA
stream . sortBy ( Person :: getName )
groupBy
- grupos por función extractora
// Java 8
stream . collect ( Collectors . groupingBy ( Person :: getName )). entrySet (). stream ()
// LSA
stream . groupBy ( Person :: getName )
chunkBy
: particiones ordenadas por función clasificadora
Stream . of ( "a" , "b" , "cd" , "ef" , "gh" , "ij" , "klmnn" )
. chunkBy ( String :: length ) // [[a, b], [cd, ef, gh, ij], [klmnn]]
sample
: emite cada enésimo elemento
Stream . rangeClosed ( 0 , 10 )
. sample ( 2 ) // [0, 2, 4, 6, 8, 10]
slidingWindow
: las particiones se transmiten en una lista de tamaño fijo y se deslizan sobre los elementos
Stream . rangeClosed ( 0 , 10 )
. slidingWindow ( 4 , 6 ) // [[0, 1, 2, 3], [6, 7, 8, 9]]
takeWhile
/ dropWhile
: introducido en Java 9, limita/omite la secuencia por función de predicado
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
: aplica iterativamente la función de acumulación y devuelve Stream
IntStream . range ( 1 , 6 )
. scan (( a , b ) -> a + b ) // [1, 3, 6, 10, 15]
indexed
: agrega un índice a cada elemento, el resultado es IntPair
Stream . of ( "a" , "b" , "c" )
. indexed () // [(0 : "a"), (1 : "b"), (2 : "c")]
filterIndexed
/ mapIndexed
/ takeWhileIndexed
/ takeUntilIndexed
/ dropWhileIndexed
/ reduceIndexed
/ forEachIndexed
- especialización indexada de operadores
Stream . of ( "a" , "b" , "c" )
. mapIndexed (( i , s ) -> s + Integer . toString ( i )) // [a0, b1, c2]
No más intentos/capturas desagradables en expresiones lambda.
// Java 8
stream . map ( file -> {
try {
return new FileInputStream ( file );
} catch ( IOException ioe ) {
return null ;
}
})
// LSA
stream . map ( Function . Util . safe ( FileInputStream :: new ))
Descargue la última versión o consígala a través de Maven:
< dependency >
< groupId >com.annimon</ groupId >
< artifactId >stream</ artifactId >
< version >1.2.2</ version >
</ dependency >
o Gradle:
dependencies {
.. .
implementation ' com.annimon:stream:1.2.2 '
.. .
}
o utilice las funciones más recientes e inéditas con JitPack.
También se incluye versión para Java ME . Pagar rama javame.