如果您阅读了该
Comparator接口的文档,则可以阅读:
功能接口: 这是一个 功能接口 ,因此可以用作lambda表达式或方法引用的分配目标。
该
Comparator<T>接口因此实现为:
**@FunctionalInterface**public interface Comparator<T> { int compare(T o1, T o2); // ...}现在,如果我们看一下文档,
@FunctionalInterface我们将看到:
内容丰富的注释类型,用于指示接口类型声明 旨在成为 Java语言规范定义 的功能接口 。从概念上讲, 功能接口只有一种抽象方法
。由于默认方法具有实现,因此它们不是抽象的。如果接口声明的抽象方法覆盖的公共方法之一java.lang.Object,则该方法
也不会计入接口的抽象方法计数,因为该接口的任何实现都将具有来自java.lang.Object其他地方的实现。
因此,基本上,如果您有一个带有 一个
抽象方法的接口,并且将该接口注释为
@FunctionalInterface,则该接口是函数的目标:因为您或多或少构造了一个实现该函数接口的匿名类,而您指定的函数是唯一抽象方法的实现。
换句话说,表达式:
Comparator<Duck> byWeight = <somelambda>
是 等价 于:
Comparator<Duck> byWeight = new Comparator<Duck>(){ public int compare(Duck d1, Duck d2){ return <somelambda>(d1,d2); }}


