-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMyRecursiveTask.java
More file actions
62 lines (48 loc) · 1.6 KB
/
MyRecursiveTask.java
File metadata and controls
62 lines (48 loc) · 1.6 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
51
52
53
54
55
56
57
58
59
60
61
62
package com.study.forkjoinpool;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.RecursiveTask;
/**
* 설명 :
*
* @author Hardy(조민국) / dev.mingood@dreamus.io
* @since 2021. 01. 08
*/
class MyRecursiveTask extends RecursiveTask<Long> {
private long workLoad;
public MyRecursiveTask(long workLoad) {
this.workLoad = workLoad;
}
@Override
protected Long compute() {
String threadName = Thread.currentThread().getName();
if (this.workLoad > 16) {
System.out.println("[" + threadName + "] Splitting workLoad : " + this.workLoad);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
List<MyRecursiveTask> subtasks = new ArrayList<>(this.createSubtasks());
for (MyRecursiveTask subtask : subtasks) {
subtask.fork();
}
long result = 0;
for (MyRecursiveTask subtask : subtasks) {
result += subtask.join();
}
return result;
} else {
System.out.println("Doing workLoad myself: " + this.workLoad);
return workLoad * 3;
}
}
private List<MyRecursiveTask> createSubtasks() {
List<MyRecursiveTask> subtasks = new ArrayList<>();
MyRecursiveTask subtask1 = new MyRecursiveTask(this.workLoad / 2);
MyRecursiveTask subtask2 = new MyRecursiveTask(this.workLoad / 2);
subtasks.add(subtask1);
subtasks.add(subtask2);
return subtasks;
}
}