c# – 从Parallel.For获取结果
作者:互联网
我正在使用Parallel.For调用一个需要一段时间才能返回的Web服务,但是,我们知道我们可以同时调用它多次,并且它不会比单个调用花费更长的时间.
为此,我正在尝试Parallel.For,我真的想要检查一下我的想法是如何工作的.我可能有点过于谨慎,因为我不想搞砸应用程序,我想确保如果我们走这条路线,整个应用程序团队都知道在访问并行代码时需要做些什么.
无论如何,这是我目前的工作和理解.
public IEnumerable<HotelAvail> GetAvailability (IList<string> codes, DateTime startDate, int numNights)
{
HotelAvail[] result = new HotelAvail[codes.Count];
Parallel.For(0, codes.Count, i =>
{
string code = codes[i];
result[i] = new AvailService().
GetAvailability(
code, startDate, numNights);
});
return result;
}
AvailService获取指定日期范围(startDate numNights)的房间可用性.代码是属性的标识符.
我在开始时设置了一个具有大量空插槽的正确大小的结果数组.
然后我并行调用该服务.该服务创建一个新的HotelAvail对象,并将其放在数组中的正确位置.
完成所有操作后,我返回数组.它应该在这一点上完全填充.应该没有空白.该服务不会影响系统状态的任何其他部分 – 它只是构建一个Web服务调用,调用它,并返回一个结果对象.
我有没有看到任何问题.
就像我上面所说的那样,我可能过于谨慎,但是我在更年轻和充满活力的日子里编写多线程代码而感到厌烦,我不想再犯同样的错误.
此外,此代码最终将在ASP.NET应用程序中结束.我依稀回忆起它对多线程代码抱怨很多.我可能遇到的任何其他问题?
解决方法:
虽然我认为PLINQ会更优雅一点,但对我来说还不错:
public IEnumerable<HotelAvail> GetAvailability (IList<string> codes,
DateTime startDate,
int numNights)
{
return codes.AsParallel().AsOrdered().Select(code =>
new AvailService().GetAvailability(code, startDate, numNights))
.ToList();
}
标签:c,net-4-0,parallel-extensions 来源: https://codeday.me/bug/20190626/1297310.html