Parallel.Invoke和Parallel.Fore本质上是相同的吗? [英] Are Parallel.Invoke and Parallel.ForEach essentially the same thing?
本文介绍了Parallel.Invoke和Parallel.Fore本质上是相同的吗?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
编辑:我应该说得更清楚些;我是问这两个方法是否做同样的事情,因为如果不是这样,我想了解哪一个更有效。
示例:我有一个包含500个键值的列表。目前,我使用一个foreach
循环,它(串行地)迭代列表并为每个项目执行工作。如果我想利用多核,是否应该改用Parallel.ForEach
?为了便于讨论,假设我对这500个任务有一个500个代表的数组--调用
Parallel.Invoke
并给它一个500个代表的列表会有什么不同吗?
推荐答案
Parallel.ForEach
遍历元素列表,可以对数组的元素执行一些任务。
例如。
Parallel.ForEach(val, (array) => Sum(array));
Parallel.Invoke
可以并行调用多个函数。
例如。
Parallel.Invoke(
() => doSum(array),
() => doAvg(array),
() => doMedian(array));
从上面的示例可以看出,它们在功能上是不同的。ForEach
循环访问List
个元素并对每个元素并行执行一个任务,而Invoke
可以对一个单个元素并行执行多个任务。
这篇关于Parallel.Invoke和Parallel.Fore本质上是相同的吗?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文