gpt4 book ai didi

java - ForkJoinPool.commonPool() 和 new ForkJoinPool(availableCPU - 1) 有什么区别?

转载 作者:行者123 更新时间:2023-11-30 12:08:01 26 4
gpt4 key购买 nike

在我的代码中,我有一个包含静态最终变量的类

private static final ForkJoinPool pool = new ForkJoinPool(availableCPUs - 1);

我有一个长时间运行的任务提交到池中,它会占用所有的 CPU 资源。提交的任何其他任务都将挂起。但是,当我切换到创建公共(public)池时

private static final ForkJoinPool pool = ForkJoinPool.commonPool();

所有的任务都可以提交和执行。

我只是想知道这两段代码之间有什么区别。 commonPool() 仍然调用 new ForkJoinPool() 并传递 availableCPUs - 1

我还注意到 commonPool() 使用类型为 SafeForkJoinWorkerThreadFactory 的工厂,而 new ForkJoinPool() 使用 ForkJoinPool$DefaultForkJoinWorkerThreadFactory。这重要吗?

非常感谢!

最佳答案

我想我明白了。

ForkJoin 维护两种类型的队列:一种是通用入站队列,一种是针对每个工作线程的工作线程队列。所有工作线程都将首先从通用入站队列中获取并填充它们的工作线程。当一个工作线程完成其工作队列中的所有任务后,它会尝试从其他工作线程窃取。如果没有其他任务可以从其他工作线程窃取,工作线程将再次从通用入站队列中获取。

不过,有了common pool,主线程也会帮忙处理任务。主线程虽然没有工作队列。因此,在完成一个任务后,主线程将能够从一般入站队列中获取。

因为默认情况下,ForkJoin 队列是 LIFO,主线程将能够获取最后提交的任务。

关于java - ForkJoinPool.commonPool() 和 new ForkJoinPool(availableCPU - 1) 有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54525379/

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