gpt4 book ai didi

java - ForkJoinPool 创造了大量的 worker

转载 作者:行者123 更新时间:2023-11-30 02:59:02 24 4
gpt4 key购买 nike

我使用 ForkJoinPool 并行执行任务。当我查看程序的注销时,ForkJoinPool 似乎创建了大量工作人员来执行我的任务(日志条目如下所示: 05 Apr 2016 11:39:18,678 [ForkJoinPool-2-worker-2493] <message> )。

创建的每个任务是否都有一个工作人员,然后根据我在 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
}
}
}

最佳答案

任务名称末尾的数字与池使用的实际线程数无关。看一下ForkJoinPool类的registerWorker方法。它看起来像这样:

final WorkQueue registerWorker(ForkJoinWorkerThread wt) {
UncaughtExceptionHandler handler;
wt.setDaemon(true); // configure thread
if ((handler = ueh) != null)
wt.setUncaughtExceptionHandler(handler);
WorkQueue w = new WorkQueue(this, wt);
int i = 0; // assign a pool index
int mode = config & MODE_MASK;
int rs = lockRunState();
...
// some manipulations with i counter
...
wt.setName(workerNamePrefix.concat(Integer.toString(i >>> 1)));
return w;
}

workerNamePrefix 初始化为

"ForkJoinPool-" + nextPoolId() + "-worker-" 

如果您想测量池使用的实际线程数,您最好记录 getPoolSize() 返回的内容。

关于java - ForkJoinPool 创造了大量的 worker ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36422654/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com