c#中的并行和工作分工?
发布时间:2020-12-15 05:36:51 所属栏目:百科 来源:网络整理
导读:(假设我有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?) 解决方法
>没有记录.工作任务可能会从共享工作池中检出大量工作.可能他们一次只需要不到10个项目,因为服用10个项目将导致不到10个线程在Parallel.For操作结束时正在工作.单个慢线程可能会创建顺序瓶颈,因为它可能是唯一仍在运行的线程.最好将工作分成较小的块,以便这种类型的瓶颈变小. >我不知道.我很确定必须使用Reflector来撬出这些信息. >它指的是全局索引,因此您可以使用它来访问共享列表或其他内容.我所见过的每一位工作代表都将是独一无二的.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |