Java 8流的新类java.util.stream.Collectors实现了java.util.stream.Collector接口,同时又提供了大量的方法对流 (stream) 的元素执行mapandreduce操作,或者统计操作。
Collectors.collectingAndThen() 函数应该最像 map and reduce 了,它可接受两个参数,第一个参数用于 reduce操作,而第二参数用于 map操作。
也就是,先把流中的所有元素传递给第一个参数,然后把生成的集合传递给第二个参数来处理。
例如下面的代码
[1,2,3,4] 这个集合传递给 v -> v * 2 lambda表达式,计算得出结果为[2,4,6,8][2,4,6,8]传递给 Collectors.averagingLong 表达式,计算得出 5.0s -> s * s lambda表达式,计算得到结果为 25.0@Test
public void collectingAndThenExample() {List list = Arrays.asList(1, 2, 3, 4);Double result = list.stream().collect(Collectors.collectingAndThen(Collectors.averagingLong(v -> {System.out.println("v--" + v + "--> " + v * 2);return v * 2;}),s -> {System.out.println("s--" + s + "--> " + s * s);return s * s;}));System.out.println(result);
}
v--1--> 2
v--2--> 4
v--3--> 6
v--4--> 8
s--5.0--> 25.0
25.0
一点唠叨:
Collectors.averagingDouble()来说,方法体只执行一次。Collectors.averagingDouble()来说,方法体做出了优化Collectors.averagingDouble()来说,这个没有坑Collectors.averagingDouble(),因为Collectors.averagingDouble()有坑,有坑,有坑