Primitive streams and optional
Remi Forax
forax at univ-mlv.fr
Sun Nov 25 10:06:06 PST 2012
On 11/25/2012 07:02 PM, Tim Peierls wrote:
> On Sun, Nov 25, 2012 at 12:25 PM, Remi Forax <forax at univ-mlv.fr
> <mailto:forax at univ-mlv.fr>> wrote:
>
> This would be more appealing with OptionalXxx, moving the
> Supplier argument away from the stream and onto the Optional
> object itself:
>
> return s.least().or(() -> computeDefaultValue());
>
>
> sorry, but why do you want to create an Optional if there is no
> option. When you provide a supplier, if there is no result, the
> supplier is called to provide one so at the end there is always a
> value. I like intermediary state in a builder only when necessary.
>
>
> When I use "Optional" I mean specifically the Guava semantics. I think
> it's worth the extra object creation to be able to simplify the stream
> API.
>
> I understand that Doug and others disagree violently with me. :-)
>
>
> Optional is interesting only if it's a pseudo class recognized by
> the language that let you call any methods you want on it,
> i.e. if Optional acts as a reified null object. We are far from that.
>
>
> Straw man argument.
ask yourself why Guava's Optional declares a method transform() by example.
>
> --tim
Rémi
More information about the lambda-libs-spec-observers
mailing list