私はForkJoinPoolを使用してタスクを並列に実行します。私のプログラムのログアウトを見ると、ForkJoinPoolは自分のタスクを実行するために膨大な量の作業者を作成しているようです(このようなログエントリがあります:05 Apr 2016 11:39:18,678 [ForkJoinPool-2-worker-2493] <message>
)。ForkJoinPoolは膨大な量の作業者を作成します
その後、私はForkJoinPoolで構成されるか、または私が何か間違ったことをやっている並列処理の数に応じて実行されて作成された各タスクのための労働者がありますか?ここで私はそれを行う方法です:
public class MyClass {
private static final int NUM_CORES = Runtime.getRuntime().availableProcessors();
public MyClass() {
int maxThreads = NUM_CORES * 2;
this.forkJoinPool = new ForkJoinPool(maxThreads);
}
public void doStuff() {
final int[] toIndex = {0};
forkJoinPool.submit(() -> {
List<ForkJoinTask> tasks = new ArrayList<>();
while (toIndex[0] < objects.size()) {
toIndex[0] += 20;
List<Object> bucket = objects.subList(toIndex[0] - 20, toIndex[0]);
ForkJoinTask task = new UpdateAction(bucket);
tasks.add(task);
task.fork();
}
tasks.forEach(ForkJoinTask::join);
}).join();
}
private class UpdateAction extends RecursiveAction {
private List<Object> bucket;
private UpdateAction(List<Object> bucket) {
this.bucket = bucket;
}
@Override
protected void compute() {
// do some calculation
}
}
}
は、ソース(GrepCode)を見ると - 数は、ちょうどすべてのForkJoinPools間で共有され、新しいワーカーが作成されたときにインクリメント一般的なカウンタです。これは、ForkJoinPoolにスレッドがいくつあるかを反映しません。 – Fildor