32 lines
925 B
Java
32 lines
925 B
Java
// threads/CountingStream.java
|
|
// (c)2016 MindView LLC: see Copyright.txt
|
|
// We make no guarantees that this code is fit for any purpose.
|
|
// Visit http://mindviewinc.com/Books/OnJava/ for more book information.
|
|
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:
|
|
4 ForkJoinPool.commonPool-worker-5 100
|
|
2 ForkJoinPool.commonPool-worker-1 100
|
|
6 main 100
|
|
5 ForkJoinPool.commonPool-worker-1 100
|
|
7 ForkJoinPool.commonPool-worker-4 100
|
|
1 ForkJoinPool.commonPool-worker-3 100
|
|
8 ForkJoinPool.commonPool-worker-2 100
|
|
0 ForkJoinPool.commonPool-worker-6 100
|
|
9 ForkJoinPool.commonPool-worker-7 100
|
|
3 ForkJoinPool.commonPool-worker-5 100
|
|
1000
|
|
*/
|