Constructing parallel streams

Joe Bowbeer joe.bowbeer at gmail.com
Mon Dec 10 08:01:39 PST 2012


I can easily imagine a pipeline that has alternating
sequential/parallel/sequential segments.  Is there any reason to discourage
a programmer from using the parallel/sequential methods to express this?
On Dec 10, 2012 7:50 AM, "Brian Goetz" <brian.goetz at oracle.com> wrote:

> I don't like users being able to call parallel in the middle of the
>> stream construction.
>>
>
> I don't love it either.  The semantics are perfectly tractible, and the
> implementation is perfectly straightforward, but the performance is
> unlikely to be a win in most cases.  (I mentioned earlier we would doc that
> this really should only be done at the head of the pipeline.)
>
>  I propose to have an interface ParallelizableStream that allows to
>> choose if the user want the sequential or the parallel stream upfront.
>>
>
> Yeah, we investigated this direction first.  Combinatorial explosion:
> IntParallelizableStream, etc.
>
> However, this could trivially become a dynamic property of streams (fits
> easily into the existing stream flags mechanism).  Then only the head
> streams would have the property, and if you tried to do parallel() farther
> down the stream, we could ignore it or even throw ISE.
>
>


More information about the lambda-libs-spec-observers mailing list