注:写这个文档只是为了方便加深记忆,加强理解,重点关注两个default方法中泛型【V】。
JDK8作为一个还在维护阶段的长期版本,势必会在企业应用中占据相当大的市场份额,所以还是以JDK8作为例子的背景。(下一个长期版本是今年9月发布的JDK11)
函数接口定义:
Interface Function<T,R>
这里稍稍说明一下接口中的<T,R>泛型的含义
- T 函数的输入类型
- R 函数的输出类型
接口内还有第三个泛型,重点关注
- V after函数的输出类型和before函数的输入类型
接口中定义了4个方法,其中apply是抽象方法,其余的三个是接口自带,不需要实现。这里定义当前函数的名称为currentFunc。
- R apply(T t)
此方法为函数的执行入口,传入T,输出R。所有标注了@FunctionalInterface注解的接口,最好都按照这个规范来定义此方法。
- default <V> Function<T, V> andThen(Function<? super R, ? extends V> after)
此方法的参数一个后置函数,执行顺序:after.apply( currentFunc.apply(t))。这里我们看看after函数的定义:Function<? super R, ? extends V> after,入参是R,输出是V,也就是说,currentFunc函数的输出[R]直接作为了after函数的入参,最终[andThen]方法的返回值:Function<T, V>,T -> currentFunc的入参,V -> after的输出类型。有过linux命令操作的朋友对此应该比较熟悉,类似于linux的管道命令,前者的输出直接当成后续命令的输入,如:cat test.txt | grep 'XXXX'
- default <V> Function<V, R> compose(Function<? super V, ? extends T> before)
此方法的参数一个前置函数,执行顺序:currentFunc.apply( before.apply(t)),before的入参类型为V,输出值类型为T;其中before的输出值[T]直接作为currentFunc的入参。[compose]方法返回函数:Function<V, R>,V -> before的入参,R -> currentFunc的输出类型。
- static <T> Function<T, T> identity()
此静态方法的作用比较单一,返回函数定义中的入参【T】