函数式接口在Java中是指:有且仅有一个抽象方法的接口。
当然接口中可以包含其他的方法(默认,静态,私有)。
函数式接口,即适用于函数式编程场景的接口。而Java中的函数式编程体现就是Lambda,所以函数式接口就是可以适用于Lambda使用的接口。只有确保接口中有且仅有一个抽象方法,Java中的Lambda才能顺利地进行推导。
备注:“语法糖”是指使用更加方便,但是原理不变的代码语法。例如在遍历集合时使用的for-each语法,其实底层的实现原理仍然是迭代器,这便是"语法糖"。从应用层面来讲,Java中的Lambda可以被当做是匿名内部类的“语法糖”,但是二者在原理上是不同的。
格式:
只要确保接口中有且仅有一个抽象方法即可:
修饰符 interface 接口名称{
public abstract 返回值类型 方法名称(可选参数信息);
//其他非抽象方法内容}
可以在定义函数式接口前添加@FunctionalInterface注解
作用:可以检测接口是否是一个函数式接口
是:编译成功
否:编译失败(接口中没有抽象方法或者抽象方法的个数多余1个)
函数式接口的使用:一般可以作为方法的参数和返回值类型
有些场景的代码执行后,结果不一定会被使用,从而造成性能浪费。而Lambda表达式是延迟执行的,这正好可以作为解决方案,提升性能。
java.util.function.Supplier<T>接口仅包含一个无参的方法:T get()。用来获取一个泛型参数指定类型的对象数据。由于这是一个函数式接口,这也就意味着对应的Lambda表达式需要"对外提供"一个符合泛型类型的对象数据。
Supplier<T>接口被称之为生产型接口,指定接口的泛型是什么类型,那么接口中的get方法就会生产什么类型的数据.
java.util.function.Consumer<T>接口则正好与Supplier接口相反,
它不是生产一个数据,而是消费一个数据,其数据类型由泛型决定。
Consumer接口中包含抽象方法void accept(T t),意为消费一个指定泛型的数据。
Consumer接口是一个消费型接口,泛型执行什么类型,就可以使用accept方法消费什么类型的数据至于具体怎.么消费(使用)需要自定义(输出,计算....)
consumer接口的默认方法andThen
作用:需要两个Consumer接口,可以把两个Consumer·接口组合到一起,在对数据进行消费
例如:
consumer<String> coni
consumer<String> con2
String s = "hello";
con1.accept(s);
con2.accept(s);
连接两个Consumer接口,再进行消费
con1.andThen( con2).accept(s);谁写前边谁先消费。
java.utiL.function .Predicate<T>接口
作用:对某种数据类型的数据进行判断,结果返回一个boolean值
Predicate接口中包含一个抽象方法:
boolean test(T t):用来对指定数据类型数据进行判断的方法
结果:
符合条件,返回true
不符合条件,返回false
逻辑表达式:可以连接多个判断的条件
&&:与运算符,有false则false
||:或运算符,有true则true
:非(取反)运算符,取反值。
1).Predicate<T>接口中的默认方法and方法:
Predicate接口中有一个方法and,表示并且关系,也可以用于连接两个判断条件
default Predicate<T> and(Predicate<? super T> other{
Objects.requireNonNulL(other);
return (t) -> this.test(t) &&other.test(t);//等价于return pre1.and(pre2).test(s);
}
方法内部的两个判断条件,也是使用&&运算符连接起来的
2).Predicate<T>接口中的默认方法or方法:
满足一个条件即可,我们就可以使用||运算符连接两个条件
Predicate接口中有一个方法or,表示或者关系,也可以用于连接两个判断条件
default Predicate<T> or(Predicate<? super T> other) {
objects.requireNonNull(other);
return (t) -> test(t) || other.test(t);//等价于return pre1.or(pre2).test(s);
方法内部的两个判断条件,也是使用||运算符连接起来的
3).Predicate<T>接口中的默认方法netage方法:
Predicate接口中有一个方法negate,也表示取反的意思
default Predicate<T> negate() {
return (t) -> !test(t);//等价于return pre.negate().test(s);
}
java.util.function.Function<T,R>接口用来根据一个类型的数据得到另一个类型的数据,
前者称为前置条件,后者称为后置条件。
Function接口中最主要的抽象方法为:R apply(T t),根据类型T的参数获取类型R的结果。
使用的场景例如:将string类型转换为Integer类型。
Function接口中的默认方法andThen:用来进行组合操作,和Consumer<T>接口中的使用方法类似。
原文:https://www.cnblogs.com/9-King/p/13574235.html