Stream reuse in superclass
David Holmes
david.holmes at oracle.com
Thu Apr 4 22:30:01 PDT 2013
On 5/04/2013 3:22 PM, Jose wrote:
> So, if I understood you, a rule to adapt old code based on Collections to
> the new paradigm would be something like:
>
> "try to produce streams instead of collections when possible, but keep on
> consuming collections"
I'm not sure what that means.
The Stream-based API is a completely different mindset to operating
directly on Collections. I'm not sure there is a "rule" to "adapt".
David
>
>
>
> -----Mensaje original-----
> De: David Holmes [mailto:david.holmes at oracle.com]
> Enviado el: viernes, 05 de abril de 2013 3:31
> Para: Jose
> CC: lambda-dev at openjdk.java.net
> Asunto: Re: Stream reuse in superclass
>
> On 5/04/2013 6:59 AM, Jose wrote:
>> I have a class that contains a method that consumes a Stream (previously
> was
>> a Collection)
>
> And that is your problem. You can not think of operations on a stream
> the way you would a collection, as a stream is not a collection. Your
> class that operated on the elements of the collection would now become
> an operation to be passed to a suitable stream method to be applied to
> each element.
>
> David
>
>> Class Foo<T>{
>> bar(Stream<T> s){
>> .........
>> }
>> }
>>
>>
>> This method is overriden in a subclass, that first consumes the stream and
>> then calls super
>>
>> Class PowerFoo<T> extends Foo<T>{
>> bar(Stream<T> s){
>> doImportantThingsWidth(s);
>> //now the stream is consumed :-(
>> super.bar(s)
>> }
>> }
>>
>>
>> What is the recomended way to handle situations like this?.
>>
>> Curently I'm collecting the stream into a list and getting two streams
> from
>> it.
>>
>>
>
More information about the lambda-dev
mailing list