Primitive streams and optional
Remi Forax
forax at univ-mlv.fr
Tue Nov 20 14:56:44 PST 2012
On 11/20/2012 11:48 PM, Brian Goetz wrote:
> That's an option too, thanks for reminding me.
>
> Let me turn that one around. Would you be happy with a single
> min(def) method that made you choose a default value always? Or would
> you find it annoying and want something else too, for the cases when
> you know there are elements?
>
> Would you spend any time wondering what the default value should be?
>
> Would you worry about how to distinguish between the case that it
> returns the default value and the case when the default value actually
> was the minimum (a la map.get())?
>
> I would guess that if you had min(defVal) you'd also want another
> version (throwing? optional?) for the cases when some of the above
> bother you?
min(def) and min() that throws a runtime exception are a good combo IMO,
but because they can be generalize to min(IntSupplier), min(() -> def)
and min(RuntimeException::new),
i think the best combo is:
int min() that calls min(RuntimeException::new) by default
and int min(IntSupplier).
anyway, I think the same design should be applied to reduce, findFirst,
min, max, average, etc.
Rémi
>
>
>
> On 11/20/2012 5:43 PM, Tim Peierls wrote:
>> What happened to min(int defval)? That way the library doesn't have to
>> decide on a good default, but the user can.
>>
>> --tim
>>
>> On Tue, Nov 20, 2012 at 5:14 PM, Brian Goetz <brian.goetz at oracle.com
>> <mailto:brian.goetz at oracle.com>> wrote:
>>
>> We're working through implementing the primitive specialization of
>> streams now. So far, its pretty straightforward; many of the ops on
>> reference streams have an obvious analogue (e.g., filter, map,
>> forEach), and many are just not applicable (e.g., into, since there
>> are no primitive collections.) There are also a number of
>> additional methods that make sense on primitive streams, such as
>> sum(). (You can see the work in progress in the lambda repo.)
>>
>> The tricky ones are the ones that return some sort of Optional. For
>> sum() there is an obvious value to return if there are no elements
>> in the stream (zero), but for min/max/average, it would require more
>> distortion to avoid optionality. We can't expect users to know a
>> priori whether the stream is empty. Example:
>>
>> int firstOrderNumber
>> customers.flatMap(c -> /* c.orders */)
>> .map(o -> o.getOrderId())
>> .min();
>>
>> The options are:
>>
>> - throw NSEE
>> - make up a bad default (e.g., MAX_VALUE for min)
>> - return an Optional<Integer>
>> - return an OptionalInt
>>
>> The first two are pretty bad, and are asymmetric to the reference
>> streams. Creating N new OptionalXxx classes is kind of annoying and
>> bloaty. (There's an argument to be made for "Well, we're boxing
>> once at the end anyway, boxing twice with Optional<Integer> isn't
>> terrible.") Though I suspect that will be an ongoing irritant. Are
>> there other "options"?
>>
>>
More information about the lambda-libs-spec-observers
mailing list