Las secuencias proporcionan una abstracción mucho mejor para la composición de las diferentes operaciones que desea realizar además de las colecciones o secuencias de datos que ingresan. Especialmente cuando necesita asignar elementos, filtrarlos y convertirlos.
Tu ejemplo no es muy práctico. Considere el siguiente código del sitio de Oracle .
List<Transaction> groceryTransactions = new Arraylist<>();
for(Transaction t: transactions){
if(t.getType() == Transaction.GROCERY){
groceryTransactions.add(t);
}
}
Collections.sort(groceryTransactions, new Comparator(){
public int compare(Transaction t1, Transaction t2){
return t2.getValue().compareTo(t1.getValue());
}
});
List<Integer> transactionIds = new ArrayList<>();
for(Transaction t: groceryTransactions){
transactionsIds.add(t.getId());
}
se puede escribir usando secuencias:
List<Integer> transactionsIds =
transactions.stream()
.filter(t -> t.getType() == Transaction.GROCERY)
.sorted(comparing(Transaction::getValue).reversed())
.map(Transaction::getId)
.collect(toList());
La segunda opción es mucho más legible. Entonces, cuando tiene bucles anidados o varios bucles que realizan un procesamiento parcial, es un muy buen candidato para el uso de Streams / Lambda API.