它似乎沒有做下面的測試程序的深蹲。這是因爲我正在測試一個小列表嗎?AsParallel的工作原理是什麼?
static void Main(string[] args)
{
List<int> list = 0.UpTo(4);
Test(list.AsParallel());
Test(list);
}
private static void Test(IEnumerable<int> input)
{
var timer = new Stopwatch();
timer.Start();
var size = input.Count();
if (input.Where(IsOdd).Count() != size/2)
throw new Exception("Failed to count the odds");
timer.Stop();
Console.WriteLine("Tested " + size + " numbers in " + timer.Elapsed.TotalSeconds + " seconds");
}
private static bool IsOdd(int n)
{
Thread.Sleep(1000);
return n%2 == 1;
}
兩個版本都需要4秒鐘才能運行。
你是如何獲得Upto的擴展方法? – thewpfguy 2014-01-28 09:34:28