API de fluxo do Java 8 reescrita em iteradores para Java 7 e anteriores.
Supplier
, Function
, Consumer
etc);Stream
/ IntStream
/ LongStream
/ DoubleStream
(sem processamento paralelo, mas com vários métodos adicionais e com operadores personalizados);Optional
/ OptionalBoolean
/ OptionalInt
/ OptionalLong
/ OptionalDouble
;Exceptional
– forma funcional de lidar com exceções;Objects
do 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 )...
Projeto de exemplo: https://github.com/aNNiMON/Android-Java-8-Stream-Example
Ao contrário dos streams Java 8, Lightweight-Stream-API fornece a capacidade de aplicar operadores customizados.
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 ());
}
}
Você pode encontrar mais exemplos aqui.
Além dos operadores Java 8 Stream portados, a biblioteca fornece:
filterNot
- operador filter
negado
// Java 8
stream . filter ((( Predicate < String >) String :: isEmpty ). negate ())
// LSA
stream . filterNot ( String :: isEmpty )
select
- filtra instâncias de uma determinada classe
// Java 8
stream . filter ( Integer . class :: isInstance )
// LSA
stream . select ( Integer . class )
withoutNulls
- filtra apenas elementos não nulos
Stream . of ( "a" , null , "c" , "d" , null )
. withoutNulls () // [a, c, d]
sortBy
- classifica por função extratora
// Java 8
stream . sorted ( Comparator . comparing ( Person :: getName ))
// LSA
stream . sortBy ( Person :: getName )
groupBy
- agrupa por função extratora
// Java 8
stream . collect ( Collectors . groupingBy ( Person :: getName )). entrySet (). stream ()
// LSA
stream . groupBy ( Person :: getName )
chunkBy
- partições classificadas por função classificadora
Stream . of ( "a" , "b" , "cd" , "ef" , "gh" , "ij" , "klmnn" )
. chunkBy ( String :: length ) // [[a, b], [cd, ef, gh, ij], [klmnn]]
sample
- emite todos os n-ésimos elementos
Stream . rangeClosed ( 0 , 10 )
. sample ( 2 ) // [0, 2, 4, 6, 8, 10]
slidingWindow
- as partições são transmitidas para uma lista de tamanho fixo e deslizam sobre os elementos
Stream . rangeClosed ( 0 , 10 )
. slidingWindow ( 4 , 6 ) // [[0, 1, 2, 3], [6, 7, 8, 9]]
takeWhile
/ dropWhile
- introduzido no Java 9, limita/ignora fluxo por função 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 a função de acumulação e retorna Stream
IntStream . range ( 1 , 6 )
. scan (( a , b ) -> a + b ) // [1, 3, 6, 10, 15]
indexed
- adiciona um índice a cada elemento, o resultado é IntPair
Stream . of ( "a" , "b" , "c" )
. indexed () // [(0 : "a"), (1 : "b"), (2 : "c")]
filterIndexed
/ mapIndexed
/ takeWhileIndexed
/ takeUntilIndexed
/ dropWhileIndexed
/ reduceIndexed
/ forEachIndexed
- especialização indexada de operadores
Stream . of ( "a" , "b" , "c" )
. mapIndexed (( i , s ) -> s + Integer . toString ( i )) // [a0, b1, c2]
Chega de try/catch feio em expressões lambda.
// Java 8
stream . map ( file -> {
try {
return new FileInputStream ( file );
} catch ( IOException ioe ) {
return null ;
}
})
// LSA
stream . map ( Function . Util . safe ( FileInputStream :: new ))
Baixe a versão mais recente ou pegue 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 use os recursos não lançados mais recentes com o JitPack.
Versão também incluída para Java ME . Confira o branch javame.