While playing around with Java8's Streams-API, I stumbled over the following:
To convert an array of primitive wrapper classe objects into a Stream
I just have to call Stream.of(array)
. But to convert an array of primitive data types, I have to call .of(array)
from the corresponding wrapper (class) stream class (<-- that sounds silly).
An example:
final Integer[] integers = {1, 2, 3};
final int[] ints = {1, 2, 3};
Stream.of(integers).forEach(System.out::println); //That works just fine
Stream.of(ints).forEach(System.out::println); //That doesn't
IntStream.of(ints).forEach(System.out::println); //Have to use IntStream instead
My question(s):
Why is this? Does this correlate to e.g. the behaviour of Arrays.asList()
which also just works for wrapper class arrays?
Java 8 stream framework has a generic Stream<T>
for objects as elements, and three primitive streams IntStream
, LongStream
, DoubleStream
for the main three primitives. If you work with primitives, use one of those latter, in your case IntStream
.
See the picture:
What lies behind is that:
Java generics cannot work with primitive types: it is possible to have only List<Integer>
and Stream<Integer>
, but not and List<int>
Stream<int>
When the Java Collections framework was introduced, it was introduced only for classes, so if you want to have a List
of int
s, you have to wrap them to Integer
s. This is costly!
When the Java Streams framework was introduced, they decided to get around this overhead and in parallel with the "class-oriented" streams (using the generics mechanism), they introduced three extra sets of all the library functions, specifically designed for the most important primitive types: int
, long
, double
.
And see also a marvelous explanation here: https://stackoverflow.com/a/22919112/2886891