我有一个Parallel.ForEach()异步循环,用于下载一些网页。由于我的带宽有限,所以我每次只能下载x个页面,但是Parallel.ForEach会执行整个所需的网页列表。
在运行Parallel.ForEach时,是否有限制线程数或任何其他限制器的方法?
演示代码:
Parallel.ForEach(listOfWebpages, webpage => {
Download(webpage);
});
真正的任务与网页无关,因此创意的网络爬虫解决方案是没有帮助的。
我有一个Parallel.ForEach()异步循环,用于下载一些网页。由于我的带宽有限,所以我每次只能下载x个页面,但是Parallel.ForEach会执行整个所需的网页列表。
在运行Parallel.ForEach时,是否有限制线程数或任何其他限制器的方法?
演示代码:
Parallel.ForEach(listOfWebpages, webpage => {
Download(webpage);
});
真正的任务与网页无关,因此创意的网络爬虫解决方案是没有帮助的。
您可以在ParallelOptions
参数中指定MaxDegreeOfParallelism
:
Parallel.ForEach(
listOfWebpages,
new ParallelOptions { MaxDegreeOfParallelism = 4 },
webpage => { Download(webpage); }
);
MSDN:Parallel.ForEach
var opts = new ParallelOptions { MaxDegreeOfParallelism = Convert.ToInt32(Math.Ceiling((Environment.ProcessorCount * 0.75) * 1.0)) };
- jKlaus您可以使用ParallelOptions并将MaxDegreeOfParallelism设置为限制并发线程的数量:
Parallel.ForEach(
listOfwebpages,
new ParallelOptions{MaxDegreeOfParallelism=2},
webpage => {Download(webpage);});
使用另一种重载的 Parallel.Foreach
,该重载接受一个 ParallelOptions
实例,并设置 MaxDegreeOfParallelism
以限制并行执行的实例数量。
对于VB.net用户(语法很奇怪,难以找到)...
Parallel.ForEach(listOfWebpages, New ParallelOptions() With {.MaxDegreeOfParallelism = 8}, Sub(webpage)
......end sub)
var options = new ParallelOptions { MaxDegreeOfParallelism = Environment.ProcessorCount };
Parallel.ForEach(myList, options, iter => { });
Environment.ProcessorCount
来增加或减少对CPU的压力。