如何将foreach转换为Parallel.foreach
本文关键字:foreach Parallel 转换 | 更新日期: 2023-09-27 17:58:49
如何转换:
foreach ( NotifyCollectionChangedEventHandler handler in delegates) {
...
}
像这样的
Parallel.ForEach( NotifyCollectionChangedEventHandler handler in delegates) {
...
}
你可以做:
Parallel.ForEach(delegates, handler =>
{
//your stuff
});
考虑以下示例
List<string> list = new List<string>()
{
"ABC",
"DEF",
"EFG"
};
Parallel.ForEach(list, str =>
{
Console.WriteLine(str);
});
您还可以看到:如何:为每个循环编写简单的并行程序
// A simple source for demonstration purposes. Modify this path as necessary.
string[] files = System.IO.Directory.GetFiles(@"C:'Users'Public'Pictures'Sample Pictures", "*.jpg");
string newDir = @"C:'Users'Public'Pictures'Sample Pictures'Modified";
System.IO.Directory.CreateDirectory(newDir);
// Method signature: Parallel.ForEach(IEnumerable<TSource> source, Action<TSource> body)
Parallel.ForEach(files, currentFile =>
{
// The more computational work you do here, the greater
// the speedup compared to a sequential foreach loop.
string filename = System.IO.Path.GetFileName(currentFile);
System.Drawing.Bitmap bitmap = new System.Drawing.Bitmap(currentFile);
bitmap.RotateFlip(System.Drawing.RotateFlipType.Rotate180FlipNone);
bitmap.Save(System.IO.Path.Combine(newDir, filename));
// Peek behind the scenes to see how work is parallelized.
// But be aware: Thread contention for the Console slows down parallel loops!!!
Console.WriteLine("Processing {0} on thread {1}", filename, Thread.CurrentThread.ManagedThreadId);
} //close lambda expression
); //close method invocation
这里,很容易:
Parallel.ForEach(delegates, handler =>
{
//Do your thing with the handler and may the thread-safety be with you.
});
尽管在阅读了这些文档后应该会很明显。
为您的目的添加一些Action<TSource>
参数参数:
Parallel.ForEach(delegates, d => { ... });