Cancelable streams
Joe Bowbeer
joe.bowbeer at gmail.com
Sun Nov 4 07:00:41 PST 2012
Thanks. I can understand the use case.
Monte Carlo techniques, even monte carlo image production, where the user
is holding their finger on a can of spray paint for a certain period of
time. And in a computer simulation (or a paint program), the user may
actually control the simulation by holding their finger on a (virtual)
button, or by flipping a switch.
I do think it's interesting to think how one could insert such a
"regulator" into a pipeline of function applications, rather than
controlling everything at the generator.
If the Stream (and ParallelStream) elements are obtained entirely by "pull"
then it should be possible to create a stage where the elements are
produced (or not) according to a timer or external signal, which seems like
a generalization of your problem: an element is produced every time a
signal is received.
Do the interfaces permit this?
On Sun, Nov 4, 2012 at 5:01 AM, Brian Goetz <brian.goetz at oracle.com> wrote:
> > I'm familiar with infinite streams (I was a tech. reviewer for the
> original Wizard Book) but I'm not familiar with your approach to
> cancellation. Is there any precedent for it?
>
> This is a use case that shows up in real-time analytics. There's a stream
> of data, and you want to chew on it for as long as you have cycles, but
> want to shut down gracefully when asked to.
>
> > To handle cancellation, I would signal the generator to stop returning
> elements, or to generate a (null) marker to signal end of stream.
>
> >
> > In other words, cancellation should be handled at the generator, not by
> Streams in general.
>
> And this discussion is basically over the use of the word "should" in the
> above sentence. There are lots of places it *could* be handled, including
> just telling the user to cut the the power to the box when they're done.
>
>
>
More information about the lambda-libs-spec-observers
mailing list