gpt4 book ai didi

c# - 为什么 PLINQ 只使用两个线程?

转载 作者:太空狗 更新时间:2023-10-29 20:02:15 24 4
gpt4 key购买 nike

假设我有一个 IO 绑定(bind)任务。我正在使用 WithDegreeOfParallelism = 10 和 WithExecution = ForceParallelism 模式,但查询仍然只使用两个线程。为什么?

我知道 PLINQ 通常会选择与我的核心数相等的并行度,但为什么它会忽略我对更高并行度的特定要求?

static void Main(string[] args)
{
TestParallel(0.UpTo(8));
}

private static void TestParallel(IEnumerable<int> input)
{
var timer = new Stopwatch();
timer.Start();
var size = input.Count();

if (input.AsParallel().
WithDegreeOfParallelism(10).
WithExecutionMode(ParallelExecutionMode.ForceParallelism).
Where(IsOdd).Count() != size / 2)
throw new Exception("Failed to count the odds");

timer.Stop();
Console.WriteLine("Tested " + size + " numbers in " + timer.Elapsed.TotalSeconds + " seconds");
}

private static bool IsOdd(int n)
{
Thread.Sleep(1000);
return n%2 == 1;
}

最佳答案

PLINQ 尝试找到最佳线程数以尽快执行您希望它执行的操作,如果您的 cpu 上只有 2 个内核,那么该数目很可能是 2。如果您有一个四核,您更有可能看到 4 个线程出现,但在双核机器上创建 4 个线程并不会真正提高性能,因为只有 2 个线程可以同时处于事件状态。

此外,对于基于 IO 的操作,任何额外的线程都可能会简单地阻塞在执行的第一个 IO 操作上。

关于c# - 为什么 PLINQ 只使用两个线程?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1812657/

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