以Comparator为例子,通常我们要排序的话需要定义一个自定义比较器。而这个比较器Comparator就是一个函数式接口。
所谓的函数式接口简单点来说,就是只有一个作为方法入参的抽象类,当使用函数式编程的时候,会自动入参在这个方法里面(即把compare实现)。在Comparator里面就是
int compare(T o1, T o2);
Collections.sort(tickets, (a, b) -> a.get(1).compareTo(b.get(1)));
并且还可以有很多个一般方法(并不式抽象的)。
比如:Comparator.comparing。具体怎么使用在另外一个文章来简化上面第二行代码。
public static <T, U extends Comparable<? super U>> Comparator<T> comparing(
Function<? super T, ? extends U> keyExtractor)
{
Objects.requireNonNull(keyExtractor);
return (Comparator<T> & Serializable)
(c1, c2) -> keyExtractor.apply(c1).compareTo(keyExtractor.apply(c2));
}