繁体   English   中英

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

[英]Parallel and work division in c#?

(假设我有10个核心)

我写的时候:

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

问题:

  1. 为每个核心分配数量的公式是什么? (是100/10 ?)

  2. 在执行点,每个核心是否已经知道要处理哪些数字? 或者它每次从[0..100]存储库中使用新数字时消耗(让我们暂时忽略块或范围)?

  3. i参数 - 是指0..100索引还是每个线程中的相对索引及其“处理”数字?

  1. 它没有记录。 工作任务可能会从共享工作池中检出大量工作。 可能他们一次只需要不到10个项目,因为服用10个项目将导致不到10个线程在Parallel.For操作结束时正在工作。 单个慢线程可能会创建顺序瓶颈,因为它可能是唯一仍在运行的线程。 最好将工作分成较小的块,以便这种类型的瓶颈变小。

  2. 我不知道。 我很确定必须使用Reflector来撬出这些信息。

  3. 它引用全局索引,因此您可以使用它来访问共享列表或其他内容。 i见过的每一位工作代表都将是独一无二的。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM