IntStream.sum
Remi Forax
forax at univ-mlv.fr
Wed Jan 16 05:15:43 PST 2013
On 01/16/2013 02:14 PM, Joe Bowbeer wrote:
>
> Normally I would side with the stricter argument in order to avoid
> potential harm, but in this case I don't see the problem.
>
the problem is that id doesn't solve the overflow problem, it just hide
it more.
> Code quality tools will flag the (int), right?
>
yes, raising the number of false positive warnings.
> And long can hold the result of MAXINT additions?
>
stream are sized is store in a long if a size if definite or can be infinite
so it solves nothing.
Rémi
> On Jan 16, 2013 4:01 AM, "Remi Forax" <forax at univ-mlv.fr
> <mailto:forax at univ-mlv.fr>> wrote:
>
> 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