所谓函数式接口,指的是只有一个抽象方法的接口。
函数式接口可以被隐式转换为Lambda表达式。
函数式接口可以用@FunctionalInterface注解标识。
JDK1.8之前就出现了一些符合函数式接口定义的接口:
- java.lang.Runnable
- java.util.concurrent.Callable
- java.security.PrivilegedAction
- java.util.Comparator
- java.io.FileFilter
- java.nio.file.PathMatcher
- java.lang.reflect.InvocationHandler
- java.beans.PropertyChangeListener
- java.awt.event.ActionListener
- javax.swing.event.ChangeListener
JDK1.8之后,又添加了一组函数式接口:
java.util.function.*
这个路径下有一大堆接口,都是函数式接口,代表了接口调用的各种不同应用场景。
另外,在JDK1.8开始,之前就有的函数式接口(比如Runnable接口)也都添加了@FunctionalInterface注解。
下面举几个java.util.function下的函数式接口的例子。
1,Consumer<T>
接口唯一的抽象方法是:
void accept(T t);
这是一个单参数,无返回值的方法,参数是泛型类。这个接口被称为消费型接口,因为没有返回值,接口里面干了什么和调用方没什么关系。
这种单参数无返回值的接口我们可以这么用Lambda表达式:
import java.util.function.Consumer;
public class Test {
public static void main(String[] args) {
Consumer consumer = (a) -> System.out.println("this is " + a);
consumer.accept("123");
}
}
输出的结果是:
this is 123
2,Supplier<T>
接口唯一的抽象方法是:
T get();
这是一个无参数,有返回值的方法,返回值类型是泛型类。这个接口被称作供给型接口。
这种无参数有返回值的方法我们可以这么用:
import java.util.function.Supplier;
public class Test {
public static void main(String[] args) {
Supplier<String> supplier = () -> "abc";
String result = supplier.get();
System.out.println(result);
}
}
3,ToIntFunction<T>
接口唯一的抽象方法是:
int applyAsInt(T value);
这是一个单参数,返回值为int的方法,参数类型是泛型类。
使用例子:
import java.util.function.ToIntFunction;
public class Test {
public static void main(String[] args) {
ToIntFunction<String> toIntFunction = (a) -> {
return Integer.parseInt(a);
};
int result = toIntFunction.applyAsInt("123");
System.out.println(result);
}
}
关于@FunctionalInterface注解
@FunctionalInterface注解是对函数式接口的标识,他的作用是对接口进行编译级别的检查,如果一个接口使用了这个注解,但是写了两个抽象方法,会出现编译错误。
以上