Parallel.ForEach 和 ForEach 与 Parallel.For 和 For 一样,一个是异步执行,开辟多个线程。一个是同步执行,开辟一个线程。
简单的循环 直接同步即可 要是循环读取或者写入数据库则 异步会更高效。
说明:
1.Parallel.For效率高于Parallel.Foreach,所以当For与Foreach都可以时,推荐使用For。
2.上面的代码,运行For时,你可能会发现数字是有顺序的打印出来,给人一种串行执行的错觉,你可以断点调试你的代码,会发现确实有多个线程在运行代码。
3.Parallel.For()、Parallel.Foreach()还有一些重载方法,大家可以结合实际情况使用,这里就不复述了。
public void WindowsService()
{
var service = new GuaranteeTaskInfoService();
//过滤符合时间段的保障
List<GuaranteeTaskInfo> lg = service.GetGuaranteeTaskInfoAll((int)State.Open);
Parallel.ForEach(lg, guartee =>
{
DoService(guartee);
});
}
网上看别人的写法:
ParallelLoopResult result = Parallel.ForEach(intList, (s,pls,longs) => { Console.WriteLine(longs + " " + s); pls.Stop(); if (pls.IsStopped) { Parallel.Invoke(Gs,Ks);//异步调用多个方法 } });
for
Stopwatch sw = new Stopwatch(); sw.Start(); ParallelLoopResult result = Parallel.For(0, 10, i => { Console.Write(""); Thread.Sleep(1); }); sw.Stop(); TimeSpan ts2 = sw.Elapsed; Console.WriteLine("Parallel.For总共花费{0}ms.", ts2.TotalMilliseconds); // Stopwatch sw_Eq = new Stopwatch(); sw_Eq.Start(); for (int i = 0; i < 10; i++) { Console.Write(""); Thread.Sleep(1); } sw_Eq.Stop(); TimeSpan tssw_Eq = sw_Eq.Elapsed; Console.WriteLine("for总共花费{0}ms.", tssw_Eq.TotalMilliseconds); Console.ReadKey();