2016-11-23 09:05:26 -08:00
|
|
|
// concurrent/CountingStream.java
|
2021-01-31 15:42:31 -07:00
|
|
|
// (c)2021 MindView LLC: see Copyright.txt
|
2016-07-05 14:46:09 -06:00
|
|
|
// We make no guarantees that this code is fit for any purpose.
|
2016-09-23 13:23:35 -06:00
|
|
|
// Visit http://OnJava8.com for more book information.
|
2017-05-17 21:38:05 -06:00
|
|
|
// {VisuallyInspectOutput}
|
2016-07-05 14:46:09 -06:00
|
|
|
import java.util.*;
|
|
|
|
import java.util.concurrent.*;
|
|
|
|
import java.util.stream.*;
|
|
|
|
|
|
|
|
public class CountingStream {
|
|
|
|
public static void main(String[] args) {
|
|
|
|
System.out.println(
|
|
|
|
IntStream.range(0, 10)
|
|
|
|
.parallel()
|
|
|
|
.mapToObj(CountingTask::new)
|
|
|
|
.map(ct -> ct.call())
|
|
|
|
.reduce(0, Integer::sum));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* Output:
|
2017-05-10 11:45:39 -06:00
|
|
|
1 ForkJoinPool.commonPool-worker-3 100
|
2017-05-03 12:00:00 -06:00
|
|
|
8 ForkJoinPool.commonPool-worker-2 100
|
2017-05-10 11:45:39 -06:00
|
|
|
0 ForkJoinPool.commonPool-worker-6 100
|
|
|
|
2 ForkJoinPool.commonPool-worker-1 100
|
|
|
|
4 ForkJoinPool.commonPool-worker-5 100
|
|
|
|
9 ForkJoinPool.commonPool-worker-7 100
|
2017-05-03 12:00:00 -06:00
|
|
|
6 main 100
|
2017-05-10 11:45:39 -06:00
|
|
|
7 ForkJoinPool.commonPool-worker-4 100
|
|
|
|
5 ForkJoinPool.commonPool-worker-2 100
|
|
|
|
3 ForkJoinPool.commonPool-worker-3 100
|
2016-07-05 14:46:09 -06:00
|
|
|
1000
|
|
|
|
*/
|