I assume you are running this under Java 9? You are not altering the SIZED
property of the stream, so there is no need to execute either map
or peek
at all.
In other words all you care is about count
as the final result, but in the meanwhile you do not alter the initial size of the List
in any way (via filter
for example or distinct
) This is an optimization done in the Streams.
Btw, even if you add a dummy filter this will show what you expect:
values.stream ()
.map(n -> n*2)
.peek(System.out::print)
.filter(x -> true)
.count();