-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMyRecursiveAction.java
More file actions
50 lines (38 loc) · 1.31 KB
/
MyRecursiveAction.java
File metadata and controls
50 lines (38 loc) · 1.31 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
package com.study.forkjoinpool;
import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.RecursiveAction;
/**
* 설명 :
*
* @author Hardy(조민국) / dev.mingood@dreamus.io
* @since 2021. 01. 08
*/
class MyRecursiveAction extends RecursiveAction {
private long workLoad;
public MyRecursiveAction(long workLoad) {
this.workLoad = workLoad;
}
@Override
protected void compute() {
String threadName = Thread.currentThread().getName();
if (this.workLoad > 16) {
System.out.println("[" + threadName + "] Splitting workLoad : " + this.workLoad);
List<MyRecursiveAction> subtasks = new ArrayList<>(this.createSubtasks());
for (MyRecursiveAction subtask : subtasks) {
subtask.fork();
}
} else {
System.out.println("Doing workLoad myself: " + this.workLoad);
}
}
private List<MyRecursiveAction> createSubtasks() {
List<MyRecursiveAction> subtasks = new ArrayList<>();
MyRecursiveAction subtask1 = new MyRecursiveAction(this.workLoad / 2);
MyRecursiveAction subtask2 = new MyRecursiveAction(this.workLoad / 2);
subtasks.add(subtask1);
subtasks.add(subtask2);
return subtasks;
}
}