看着番石榴 ImmutableList (和其他一些类),你会发现很多超载 of
便捷方法(“按顺序返回包含给定元素的不可变列表。”),它采用不同数量的参数:
...
public static <E> ImmutableList<E> of(E e1, E e2, E e3)
public static <E> ImmutableList<E> of(E e1, E e2, E e3, E e4)
public static <E> ImmutableList<E> of(E e1, E e2, E e3, E e4, E e5)
...
一直到这个:
public static <E> ImmutableList<E> of(E e1,
E e2,
E e3,
E e4,
E e5,
E e6,
E e7,
E e8,
E e9,
E e10,
E e11,
E e12,
E... others)
我的一些同事认为这很愚蠢,想知道为什么不只有一种方法: of(E... elements)
。他们怀疑这是一个不良导向的性能“优化”,属于“你认为你比编译器更聪明”的类别,或类似的东西。
我的预感是Kevin Bourrillion等人。把这些方法放在那里是出于真正的原因。谁能解释(或推测)这个理由可能是什么?