Function parameter order

David Holmes david.holmes at oracle.com
Tue Nov 6 19:19:11 PST 2012


On 7/11/2012 2:58 AM, Kevin Bourrillion wrote:
> It sounds as though we're planning on Function<ReturnType, InputType>.

Yes. This was indicated, somewhat subtly in my view, in the review request:

- The argument lists are structured so that specializations act on the 
first argument(s), so IntMapper<T> is a specialization of Mapper<R,T>, 
and IntBinaryOperator is a specialization of BinaryOperator<T>.


I don't have a general preference other than maintaining consistency and 
given that we have Map<K,V> it seems to me that we have a long standing 
precedent to have the return type last not first.

David
-----

> I'd just like to note that this is going to put codebases that are in
> any stage of migration to JDK types from existing libraries including
> Guava in a really, really bad position.
>
> Every time I see Function<A, B> for /years/, I am going to have to check
> the imports to find out whether that's A->B or B-A.
>
> I'm not saying this consideration should trump all others. Just noting
> that I see this as a very bad problem for my user base.
>
> --
> Kevin Bourrillion | Java Librarian | Google, Inc. |kevinb at google.com
> <mailto:kevinb at google.com>
>


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