Bikeshed opportunity: filter/map/reduce naming
Brian Goetz
brian.goetz at oracle.com
Sat Dec 1 11:10:53 PST 2012
>> But, people have complained about filter because they can't tell
>> whether we are
>> filtering OUT the elements matching the predicate, or including them.
>> Some of
>> these people have suggested "where(Predicate)" as an alternative.
>> Which seems
>> OK to me.
>
> "select" is the most classic name. Especially for a database company :-)
> Also "selectAny" etc.
Given the database imperative you cite (there's also LinQ), if we were
to use select() at all, it would be for what is now called map?
xs.where(x -> x.getFoo() > 3)
.select(x -> x.getBar())
...
If/when we get tuples that might actually look nice:
xs.where(x -> x.getFoo() > 3)
.select(x -> #( x.getBar(), x.getBaz() )) // stream of (bar,baz)
...
But probably should stay away from select entirely for these reasons.
Still a slight preference for "where" over "filter":
list.where(e -> e.hasChildren())
.map(e -> e.getFirstChild())
.minBy(Child::getAge)
Other ideas?
More information about the lambda-libs-spec-observers
mailing list