tee()

Brian Goetz brian.goetz at oracle.com
Thu Jan 24 13:05:45 PST 2013


But streams *are* lazy.  What confuses people is that when you say:

   stream.filter(...)
         .map(...)
         .reduce(...)

the filtering, mapping, and reducing are all happening *at once*.  Users 
will look for a place to stick a breakpoint "after the filtering" and 
come up empty.  By putting a "peek()" call with debugging code, now they 
have a place to put a breakpoint or print stuff out, so they can debug 
complex pipelines stage by stage.

On 1/24/2013 4:02 PM, Kevin Bourrillion wrote:
> On Thu, Jan 24, 2013 at 12:53 PM, Brian Goetz <brian.goetz at oracle.com
> <mailto:brian.goetz at oracle.com>> wrote:
>
>     Don convinced me of the need for this one when he described
>     experiences his team had adapting to lazy collections in their
>     libraries.
>
>
> Depending on the details of that conversation, I either buy it or don't
> buy it. :-)
>
> Lazy collections are a whole other story; Collection<E> gets returned
> from API X and passed into API Y and people don't realize it; that lazy
> evaluation happens god-knows-when.  Stream<E> makes that a lot better.
>
>
>
>     On 1/24/2013 3:43 PM, Kevin Bourrillion wrote:
>
>         tee() stands out like a sore thumb.  I'm not surprised that
>         Brian says
>         "this method is mostly for debugging."
>
>         It just feels very, very strange to let the user inject a
>         side-effect
>         into the middle of their stream somewhere, for mysterious hidden
>         later
>         execution /maybe/.
>
>
>         If it really must stay, I think I do like "peek" or "observe" over
>         "tee". But I would love to drop it.
>
>         --
>         Kevin Bourrillion | Java Librarian | Google, Inc.
>         |kevinb at google.com <mailto:kevinb at google.com>
>         <mailto:kevinb at google.com <mailto:kevinb at google.com>>
>
>
>
>
> --
> Kevin Bourrillion | Java Librarian | Google, Inc. |kevinb at google.com
> <mailto:kevinb at google.com>


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