"Cancelable" streams

Brian Goetz brian.goetz at oracle.com
Sat Dec 8 13:51:07 PST 2012


> The main issue is that your example uses side effect,
>    () -> cancelFlag.set(true)
> which goes against the model

The model is not "side effects are illegal"; we support forEach() and 
into() which are side-effectful.  The model is more "don't use 
side-effects where they are not needed."

>  > Here, you might want to process until some threshold has been reached
>  > (find the first N results), until some external event has occured
>  > (process for five minutes and take the best result; process until the
> asked to shut down.)
>
> find the N results => use limit()

Parallel limit has some serious limitations that make it pretty 
unsuitable for this case.  While these may be fixable, the effort and 
distortion involved is far, far greater than what is being suggested 
here.  In fact, I'm on the fence about whether to keep limit at all in 
its current state; I worry people will expect more of it than it can 
deliver, and be unhappy.

> fitting the whole word and the kitchen sink into the Stream API is not a
> goal.

No, but this is a pretty lightweight cancelation mechanism -- far more 
lightweight than limit as currently implemented.  We've talked to 
customers who are very interested in using this for processing infinite 
event streams.  The only thing missing is "how do I make it stop."



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