IntStream.sum
Remi Forax
forax at univ-mlv.fr
Wed Jan 16 03:58:02 PST 2013
IntStream.sum have just been changed to return a long instead of an int
and I don't think it's a good idea.
There is 3 ways to deal with overflows:
1) do nothing, the Java default semantics
2) throw an exception if overflown (using Integer.addExact by example)
3) use BigInteger
all other ways are just half baked solution.
This one is very bad because usually users will use it that way,
int sum = (int)intStream.sum();
so it doesn't solve anything, just make the semantics awkward.
sum() is just a shortcut for a reduce, so it should stick with the
default Java semantics,
if users want longs, they can use reduce with Long::add or Long::addExact.
Rémi
More information about the lambda-libs-spec-experts
mailing list