Into
Brian Goetz
brian.goetz at oracle.com
Sat Dec 22 14:15:37 PST 2012
> 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.
+1. (This was my point #1 from the original note.)
> So why not treat these as factories in existing catgories:
> toCollection(), toList(), toRandomAccessList()
> toSet(), toNavigableSet();
> plus grouping versions
> toMap(keyfn, ...), toNavigableMap(keyFn, ...);
I like the convenience of these -- they meet the needs of many users
without forcing people to learn about the tabulators framework (or
whatever we call it). And also the flexibility of being able to provide
better implementations over time. But I prefer they be sugar on top of
something more general. So let's not let the surface simplicity of the
simple case stop us from from addressing the general case.
(One thing I don't love is that they bring List/Map back into the API --
after all the work we did in groupBy to move it out. But this is more
superficial than what groupBy/reduceBy did, so I'm probably OK with this
-- especially if they are just sugar.)
> The implementation can also take advantage of the fact
> that some collections (especially ArrayList) support fast
> parallel insertion upon creation but not once published.
Though unfortunately relies on implementation details rather than the
spec for ArrayList.
More information about the lambda-libs-spec-observers
mailing list