为了使现有函数更友好的支持Lambda表达式,Java 8引入了函数式接口的概念。函数式接口就是只有一个抽象方法的普通接口。像这样的接口,可以被隐式转换为lambda表达式。
java.lang.Runnable与java.util.Comparator是函数式接口最典型的例子。Java 8增加了一种特殊的注解@FunctionalInterface:
@FunctionalInterface
public interface MyFunctional {
void method();
}
Java中lambda无法单独出现,它需要一个函数式接口来盛放,lambda表达式方法体其实就是函数接口的实现,lambda表达式的类型就是对应函数接口的类型。
需要注意:
接口最终有确定的类实现, 而类的最终父类是Object。 因此函数式接口可以定义Object的public方法。
默认方法与静态方法并不影响函数式接口的契约,可以任意使用:
@FunctionalInterface
public interface FunctionalDefaultMethods {
void method();
String toString(); //same to Object.toString
int hashCode(); //same to Object.hashCode
boolean equals(Object obj); //same to Object.equals
Object clone(); //Object.clone is protected
default void defaultMethod() {
System.out.print(“default”);
}
default void defaultMethod2() {
}
}
Java8在java.util.function中定义了几组类型的函数式接口以及针对基本数据类型的子接口。
· Predicate --(断言)传入一个参数,返回一个bool结果, 方法为boolean test(T t)
· Consumer --(消费)传入一个参数,无返回值,纯消费。 方法为voidaccept(T t)
· Function --(函数)传入一个参数,返回一个结果,方法为Rapply(T t)
· Supplier --(生产)无参数传入,返回一个结果,方法为T get()
· UnaryOperator --一元操作符, 继承Function,传入参数的类型和返回类型相同。
· BinaryOperator --二元操作符, 传入的两个参数的类型和返回类型相同, 继承BiFunction
参考文章:
http://colobu.com/2014/10/28/secrets-of-java-8-functional-interface/