c# - 为什么在这个例子中并行版本比顺序版本慢?

标签 c# parallel-processing

最近几天我学习了一些关于并行性的知识,我遇到了 this示例。

我将它与这样的顺序 for 循环放在一起:

private static void NoParallelTest()
{
    int[] nums = Enumerable.Range(0, 1000000).ToArray();
    long total = 0;
    var watch = Stopwatch.StartNew();
    for (int i = 0; i < nums.Length; i++)
    {
        total += nums[i];
    }
    Console.WriteLine("NoParallel");
    Console.WriteLine(watch.ElapsedMilliseconds);
    Console.WriteLine("The total is {0}", total);
}

我惊讶地发现 NoParallel 方法的完成速度比网站上给出的并行示例快得多。

我有一台 i5 电脑。

我真的认为 Parallel 方法会完成得更快。

这有合理的解释吗?也许我误解了什么?

最佳答案

顺序版本更快,因为在您的示例中,在每次迭代上执行操作所花费的时间非常少,并且创建和管理多个线程涉及相当大的开销。

只有当每次迭代的处理器时间都足够昂贵时,并行编程才会提高效率。

关于c# - 为什么在这个例子中并行版本比顺序版本慢?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10418493/

相关文章:

C# 线程处理 Parallel.ForEach 和 DirectoryInfo 内存不足异常

C# 逻辑顺序和编译器行为

python - 如何编写脚本在多核机器上有效运行多进程

java - 并行与串行实现解释

c++ - OpenMP:获取正在运行的线程总数

java - 将 Spring Batch 分区配置为处理器和写入器,同时从分区中排除读取器

c# - 如何在类和派生类之间使用接口(interface)?

c# - NetworkStream:ReadTimeout 及其效果 Read()

memory - 并发写入同一内​​存地址

c# - EntityFrameworks.dll 文件丢失?