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();
————————————————
版权声明:本文为CSDN博主「主沉浮」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/u010773333/article/details/78843666