新特性中有个Function接口用在支持lamdba表达式。
个人理解这个接口就是把一些输入参数封装在1个 or n个方法内,并且输出的结果类型可以和参数一致 or 不一致。
同时可以利用这个接口不断把方法迭代,用来完成方法的组合。
如果大家对于这个类的用法还有其他的想法,欢迎留言。
1. R apply(T t) -> 将function对象应用到输入的参数上,并且输出结果
2. default <V> Function<T,V> andThen(Function<? super R, ? extends V> after) -> 先执行Function<T, R>对象的apply(),再执行after的apply(),返回一个新的Function
源码:
从源码上可以看出,先执行 Function<T, R> apply(t) = R, 然后再执行Function<R, V> apply(R) = V。 忽略过程,传入的参数为T,输出的结果为V.
我的理解为:假设n个andThen()迭代,那么就是不断用输出结果继续作为输入进行操作,最后一个出口的结果作为最终结果。
2. default <V> Function<V,R>
compose(Function<? super V,? extends T> before)
-> 先执行before的apply(),再执行Function<T,R>的apply(),返回一个新的Function
源码:
从源码上可以看出,先执行 Function<V, T> apply(v) = T, 然后再执行Function<T, R> apply(T) = R。 忽略过程,初始传入的参数为T,输出的结果为R.
我的理解为:假设n个compose()迭代,那么就是为了得到R,前面的apply()不断输出,直至得到T。
4. static <T> Function<T,T>
identity()
-> 返回一个输入和输出都为T的Function对象。
源码:
例子:
Function<String, Integer> f1 = (t) -> Integer.valueOf(t) * 10;
System.out.println(f1.apply("3"));
System.out.println(Function.identity().apply("3"));
System.out.println(f1.andThen((r) -> String.valueOf(r) + ".....").apply("4"));
System.out.println(f1.compose((String r) -> r.substring(1)).apply("a5"));
输出为:
30
3
40.....
50