(Обновление для .NET4, поскольку этот вопрос занимает довольно высокое место в поиске Google для AsParallel ())
Всего несколько изменений позволят вашему примеру работать так, как вы ожидаете.
Изменить List<int> list = 0.UpTo(4);
на var list = Enumerable.Range(0, 4);
Ваш пример сработает, если вы добавите перегрузку функции с подписью, которая принимает ParallelQuery ...
private static void Test(ParallelQuery<int> input)
{
var timer = new Stopwatch();
timer.Start();
int 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");
}
Либо вы можете использовать синтаксис LINQ ....
private static void Test(ParallelQuery<int> list)
{
var timer = Stopwatch.StartNew();
if ((from n in list.AsParallel()
where IsOdd(n)
select n).Count() != (list.Count() / 2))
{
throw new Exception("Failed to count the odds");
}
Console.WriteLine("Tested " + list.Count() + " numbers in " + timer.Elapsed.TotalSeconds + " seconds");
}
Надеюсь, это кому-нибудь поможет!