Into
Howard Lovatt
howard.lovatt at gmail.com
Sat Dec 22 18:41:39 PST 2012
In my stream library I made Stream a List. The List methods provided an immutable view into the stream and caused an eager evaluation. This was sufficient for all my needs and is very simple. I found in practice that I didn't do a lot of conversion from stream to array/collection. Once I was in stream, I tended to stay there.
Have a good Christmas break,
-- Howard.
Sent from my iPad
On 23/12/2012, at 9:24 AM, Remi Forax <forax at univ-mlv.fr> wrote:
> On 12/22/2012 09:21 PM, Doug Lea wrote:
>>
>> I'm happy to see "into" go. But I'm not all the way sold on whether
>> the best way is via more abstraction (Reducers, Tabulators, etc)
>> versus less. Here's the "less" version.
>> I don't want to argue too hard for taking this approach,
>> but figure that is worth describing:
>>
>> For mutative additions to collections/maps, why not
>> just let people use either forEach(...add...) or
>> parallel-forEach(...add..), depending on
>> whether the destination is concurrent and the source
>> amenable to parallelism, and/or whether, in the case of
>> Maps, they want put vs putIfAbsent vs merge. The idioms
>> are easy, and clearly reflect mutative intent. (*)
>
> Your asking people to take car about the concurrency in their code instead of letting the pipeline taking care of that.
> While it should be possible, that's why there is a forEach, it should not be the default idiom because people will write
> ArrayList<String> list = new ArrayList<>();
> list.parallel().filter(...).forEach(list::add);
> We should prefer a slow into() to a fast forEach() that only works if your name is Doug or Brian.
>
>>
>> For more functional/fluent/streamy usages, you'd like
>> to enforce that any into-ish method creates a fresh instance
>> and that construction cannot interfere with anything else.
>> So why not treat these as factories in existing catgories:
>> toCollection(), toList(), toRandomAccessList()
>> toSet(), toNavigableSet();
>> plus grouping versions
>> toMap(keyfn, ...), toNavigableMap(keyFn, ...);
>> (with merge- and multi- variants.)
>>
>> Here the streams implementation gets to pick the
>> underlying concrete class. This may entail sensing
>> parallelism but only in the case of toList is
>> constrained by orderedness.
>> The streams implementation could pick the best applicable
>> options and improve them or pick others over time.
>> (For example, initially,, all of toCollection(), toList(),
>> and toRandomAccessList() could pick ArrayList.)
>> The implementation can also take advantage of the fact
>> that some collections (especially ArrayList) support fast
>> parallel insertion upon creation but not once published.
>
> you can't use arrayList.addAll(arrayList2) ?
>
>>
>> People who don't like the choices of concrete classes
>> can instead use the first option of creating some concrete
>> collections and populating them.
>>
>> Summary: Replace into with:
>> * manual forEach-based idioms for mutative stuff
>> * opaque factory-based methods for fluent/function stuff
>> And triage out for now any other non-collections-based into targets
>
> on things that can be done is to write into that way:
> into(Supplier<? extends T> supplier)
> and used that way:
> stream.into(ArrayList::new)
>
> The implementation of the pipeline can check if the Supplier is a constructor reference to a well known collections of the JDK and optimize.
> But in that case, users can not use Collections.newSetFromMap.
>
>>
>> (*) footnote: There are now a few more options for
>> parallel insertions into concurrent collections.
>> A while ago I added a "newKeySet" factory
>> method to JDK8/V8 version of CHM, so
>> there is now a JDK Concurrent Set implementation
>> that people can use. Someday similarly for skip lists,
>> so there will be a concurrent sorted/navigable set.
>> High-performance concurrent Lists are unlikely any
>> time soon, although ReadMostlyVector is better
>> than nothing. (I'm still not sure if it should move
>> from jsr166e.extra into JDK...).
>>
>> -Doug
>
> RĂ©mi
>
More information about the lambda-libs-spec-observers
mailing list