c#中的并行和工作分工?
(假设我有10个核心)
我写的时候:
Parallel.For(0, 100, (i,state) => { Console.WriteLine(i); });
问题:
-
为每个核心分配数量的公式是什么? (是
100/10
?) -
在执行点,每个核心是否已经知道要处理哪些数字? 或者每次从
[0..100]
存储库中获取新数字时是否消耗(让我们暂时忽略块或范围)? -
i
参数 – 它是指0..100
索引还是每个线程中的相对索引及其“处理”数字?
-
它没有记录。 工作任务可能会从共享工作池中检出大量工作。 可能他们一次只需要不到10个项目,因为服用10个项目将导致不到10个线程在
Parallel.For
操作结束时正在工作。 单个慢线程可能会创建一个顺序瓶颈,因为它可能是唯一仍在运行的线程。 最好将工作分成较小的块,以便这种类型的瓶颈变小。 -
我不知道。 我很确定必须使用Reflector来撬出这些信息。
-
它引用全局索引,因此您可以使用它来访问共享列表或其他内容。
i
工作代表见过的每一件事都是独一无二的。