目录
一、定义
如果一个接口中,只声明了一个抽象方法,则此接口就称为函数式接口。
可以通过Lambda表达式来创建该接口的对象(若lambda表达式抛出一个受检异常,那么该异常需要在目标接口的抽象方法上进行声明)
Lambda表达式的本质就是作为函数式接口的实例
自定义函数式接口
我们可以在一个接口上使用@FunctionalInterface注解,检验是否是一个函数式接口。同时javadoc也会包含一条声明,说明这个接口是一个函数式接口
@FunctionalInterface
public interface MyInterface {
void method1();
}
二、如何理解函数式接口
Java从诞生日起就是一直倡导“一切皆对象”,在Java里面面向对象(OOP)编程是一切。但是随着python、scala等语言的兴起和新技术的挑战,Java不得不做出调整以便支持更加广泛的技术要求,也即java不但可以支持OOP还可以支持OOF(面向函数编程)
在函数式编程语言当中,函数被当做一等公民对待。在将函数作为一等公民的编程语言中,Lambda表达式的类型是函数。但是在Java8中,有所不同。在Java8中,Lambda表达式是对象,而不是函数,它们必须依附于一类特别的对象类型——函数式接口
简单的说,在Java8中,Lambda表达式就是一个函数式接口的实例。这就是Lambda表达式和函数式接口的关系。也就是说,只要一个对象是函数式接口的实例,那么该对象就可以用Lambda表达式来表示
所以以前用匿名实现类表示的现在都可以用Lambda表达式来写
三、Java内置四大核心函数式接口
函数式接口 | 参数类型 | 返回类型 | 用途 |
---|---|---|---|
Consumer<T> 消费型接口 |
T | void | 对类型为T的对象应用操作,包含方法:void accept(T t) |
Supplier<T> 供给型接口 |
无 | T | 返回类型为T的对象,包含方法:T get() |
Function<T,R> 函数型接口 |
T | R | 对类型为T的对象应用操作,并返回结果。结果是R类型的对象。包含方法:R apply(T t) |
Predicate<T> 断定型接口 |
T | boolean | 确定类型为T的对象是否满足某约束,并返回boolean值。包含方法:boolean test(T t) |
@Test
public void test1(){
happyTime(500, new Consumer<Double>() {
@Override
public void accept(Double aDouble) {
System.out.println("学习真累,买点好吃的价格为" + aDouble);
}
});
System.out.println("**********************");
happyTime(400,money -> System.out.println("学习真累,买点好吃的价格为" + money));
}
public void happyTime(double money, Consumer<Double> con){
con.accept(money);
}
@Test
public void test2(){
List<String> list = Arrays.asList("北京","南京","东京","西京");
List<String> filterStrs = filterString(list, new Predicate<String>() {
@Override
public boolean test(String s) {
return s.contains("京");
}
});
System.out.println(filterStrs);
System.out.println("*************************");
List<String> filterStrs1 = filterString(list,s -> s.contains("京"));
System.out.println(filterStrs);
}
//根据给定的规则,过滤集合中的字符串。此规则由Predicate的方法决定
public List<String> filterString(List<String> list, Predicate<String> pre){
ArrayList<String> filterList = new ArrayList<>();
for (String s : list){
if(pre.test(s)){
filterList.add(s);
}
}
return filterList;
}