c#中的并行和工作分工?

c#中的并行和工作分工?,第1张

概述(假设我有10个核心) 我写的时候: Parallel.For(0, 100, (i,state) => { Console.WriteLine(i); }); 问题: >为每个核心分配数量的公式是什么? (是100/10?) >在执行点,每个核心是否已经知道哪些数字将要处理?或者它每次从[0..100]存储库中使用新数字时消耗( (假设我有10个核心)

我写的时候:

Parallel.For(0,100,(i,state) =>           {             Console.Writeline(i);          });

问题:

>为每个核心分配数量的公式是什么? (是100/10?)
>在执行点,每个核心是否已经知道哪些数字将要处理?或者它每次从[0..100]存储库中使用新数字时消耗(让我们暂时忽略块或范围)?
> i参数 – 它是指0..100索引还是每个线程中的相对索引及其“处理”数字?

解决方法 >没有记录.工作任务可能会从共享工作池中检出大量工作.可能他们一次只需要不到10个项目,因为服用10个项目将导致不到10个线程在Parallel.For *** 作结束时正在工作.单个慢线程可能会创建顺序瓶颈,因为它可能是唯一仍在运行的线程.最好将工作分成较小的块,以便这种类型的瓶颈变小. >我不知道.我很确定必须使用Reflector来撬出这些信息. >它指的是全局索引,因此您可以使用它来访问共享列表或其他内容.我所见过的每一位工作代表都将是独一无二的. 总结

以上是内存溢出为你收集整理的c#中的并行和工作分工?全部内容,希望文章能够帮你解决c#中的并行和工作分工?所遇到的程序开发问题。

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

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1252520.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存