为了便于使用Lambda表达式进行开发,Java提供了四个核心函数式接口,这样我们写代码时只需要编写一个处理自己业务逻辑的方法,在调用方法时去实现Java提供的函数式接口,就可以简单快速的进行业务逻辑代码的编写。
消费型接口的简单实现:
Consumer<T>:消费型接口
void accept(T t);
消费型接口,顾名思义就是对应现实世界的“消费”,我们平常去消费“刀了~”时,US刀了!肯定时有去无回了,所以消费型接口没有返回值。
供给型接口的简单实现:
Supplier<T>:供给型接口
T get();
因为供给型接口不知道我们到底需要什么数据类型或者参数,所以供给型接口是无参的。里面定义了一个 T get();方法
test2()方法测试供给型接口,调用getNumList()传入第一个参数10,表示获取10个int类型的num,然后目光来到Lmabda表达式,由于供给型接口提供的抽象方法是无参的,所以Lambda表达式的左边是一个空()括号,右边是我们自己定义的参数供给给接口的抽象方法使用,Math.random
*100表示获取100以内的随机数并强制转换为int类型。
函数型接口的简单实现:
Function<T,R>:函数型接口
R apply(T t);
函数型接口给一个T(某一个类型或者某种参数)返回一个R(方法的处理结果)
Function<T,R> 例: T是一个字符串类型的参数,R是一个处理字符串的方法,R apply(T t); 表示给R方法传入T参数,返回R方法的执行结果,不多bb直接上图
例如现在有一个处理字符串的方法strHandler()在测试方法中调用strHandler()方法,第一个参数是str,这里张个眼睛就能明白,还是直接来到Lambda表达式,Lambda左边对应形参列表 R apply(T t); str对应T参数,可以把str.trim()代入fun.apply(str)得到一个完整的方法fun.apply(str){return str.trim()}。右边lambda体对应是fun.apply(str)的方法体。
fun.apply(str){
return str.trim()
}
断言型接口的简单实现
Predicate<T>:断言型接口
boolean test(T t);
断言型接口给一个参数T,Lambda体返回一个布尔类型数据
像上面一样,如果我们把Lambda表达式的右边的Lambda体代入断言型接口的抽象方法得到一个方法
pre.test(str){
if(str.length> 3){
return true;
}else
return false;
}
把这个方法的执行结果放到if(pre.test(str))中就可以很快理解Lambda表达式的处理逻辑了
当然这只是四个常用的函数式接口,还有很多扩展性的接口,需要的小伙伴可以去网上查一下相关资料这里就不过多赘述了