Fwd: Re: Stream.limit() - puzzler/bug/feature
Remi Forax
forax at univ-mlv.fr
Fri Nov 16 12:51:00 PST 2012
On 11/16/2012 05:51 PM, Brian Goetz wrote:
>> if we provide a spliterator(), we don't need the method iterator()
>> because one can call spliterator().iterator().
>
> The idea is:
> - If it's a serial stream, you grab an iterator() if you need direct
> element access.
> - If its a parallel stream, you grab a spliterator() if you need
> direct element access.
>
>> But again, I'm not sure we should provide these methods,
>> I have no idea if it worth the pain to have to implement it for all
>> streams.
>
> There's surprisingly little pain :)
>
> Every parallel stream already has a spliterator() embedded in it;
> that's how you create a parallel stream. If you have a trivial pipeline:
>
> Stream<T> pipe = foo.parallel();
>
> the library can just return the spliterator provided when the stream
> was created. (There are tools for turning various things like
> Iterable or Iterator into a (dumb) Spliterator, if that's all you
> have.) If you have a nontrivial pipeline:
>
> Stream<T> pipe = foo.parallel().map(e -> 3);
>
> then the library takes the base spliterator, and wraps it with one
> whose splitting methods just pass through to the underlying
> spliterator, and whose iterator method uses the wrapIterator methods
> of the op chain. Painless.
>
>
> Where there is some pain is specifying it, and what the interactions
> are with other actions. Such as, does calling (spl)iterator mean you
> can't call a terminal op?
yes, asking for an iterator is a terminal op too.
> What happens when you call iterator twice?
you can't. see above :)
> Do you get the same iterator? What happens when you call iterator
> and then spliterator? But, I think we have to spec these things anyway.
>
again, when you call a terminal method, it freezes the whole streams
chain back to the stream created with Streamable.stream(),
so you can't call a terminal ops twice otherwise you have to specify all
combinations by example what if I call findFirst() then forEach().
Rémi
More information about the lambda-libs-spec-observers
mailing list