我正在查看Map接口的Java源代码,并遇到了一小段代码:
/**
* Returns a comparator that compares {@link Map.Entry} in natural order on value.
*
*
The returned comparator is serializable and throws {@link
* NullPointerException} when comparing an entry with null values.
*
* @param the type of the map keys
* @param the {@link Comparable} type of the map values
* @return a comparator that compares {@link Map.Entry} in natural order on value.
* @see Comparable
* @since 1.8
*/
public static > Comparator> comparingByValue() {
return (Comparator> & Serializable)
(c1, c2) -> c1.getValue().compareTo(c2.getValue());
}
从方法声明中我得到的是,这是一个泛型方法,它返回一个类型的Comparator,该类型可以从传递给它的映射条目推断出来,也可以在方法中明确提供.
什么真正让我失望的是回报价值.看来lambda表达式
(c1, c2) -> c1.getValue().compareTo(c2.getValue());
显式地转换为比较器< Map.Entry< K,V>>.这是正确的吗?
我也注意到,明显的演员包括&序列化.我以前从未见过一个接口与一个类中的类相结合,但它看起来像编译器中的以下有效:
((SubClass& AnInterface)anObject).interfaceMethod();
虽然以下不起作用:
public class Foo {
public static void main(String[] args) {
Object o = new Foo() {
public void bar() {
System.out.println("nope");
}
};
((Foo & Bar) o).bar();
}
}
interface Bar {
public void bar();
}
那么,有两个问题:
>如何为演员添加界面?这只是强制执行接口方法的返回类型吗?
>你可以将一个Lambda表达式转换为比较器吗?他们还可以演绎什么呢?或者lambda表达式本质上只是一个比较器?有人可以澄清这一切吗?