C&C++   发布时间:2022-04-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了为什么C#Parallel.Invoke很慢?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我这样做:

private static void Main(String[] args)
    {
        var Dict1 = new Dictionary<int,String>();
        var Dict2 = new Dictionary<int,String>();
        datetiR_867_11845@e t1 = datetiR_867_11845@e.Now;
        for (int i = 1; i < 1000000; i++)
        {
            Parallel.Invoke(
                  () => Dict1.Add(i,"Test" + i),() => Dict2.Add(i,"Test" + i) );
        }
        TimeSpan t2 = datetiR_867_11845@e.Now.Subtract(t1);

        Console.WriteLine(t2.@R_708_10586@lMilliseconds);

        Console.ReadLine();
    }

因此,做一个100万次的循环并将项目添加到两个不同的词典.
问题是需要11秒,这比普通顺序方法(没有任务/线程)多5倍,仅需2秒.
不知道为什么.

解决方法

像其他人所说或暗示的那样,由于并行化的开销,并行代码并不总是更快.

这么说,你的代码是并行地向2个字典添加一个项目1M次,而你应该并行添加1M项到2个字典.差异很微妙,但最终结果是代码你的连续案例快10%(在我的机器上).

Parallel.Invoke(() => FillDictionary(Dict1,1000000),() => FillDictionary(Dict2,1000000));

...

private static void FillDictionary(Dictionary<int,String> toFill,int itemCount)
{
    for(int i = 0 ; i < itemCount; i++)
        toFill.Add(i,"test" + i);
}

大佬总结

以上是大佬教程为你收集整理的为什么C#Parallel.Invoke很慢?全部内容,希望文章能够帮你解决为什么C#Parallel.Invoke很慢?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。