Supongamos que tengo una tarea vinculada a IO. Estoy usando WithDegreeOfParallelism = 10 y WithExecution = ForceParallelism mode, pero la consulta solo usa dos hilos. ¿Por qué?¿Por qué PLINQ usa solo dos hilos?
Entiendo que PLINQ usualmente elegirá un grado de paralelismo igual a mi conteo de núcleos, pero ¿por qué ignora mi solicitud específica de mayor paralelismo?
static void Main(string[] args)
{
TestParallel(0.UpTo(8));
}
private static void TestParallel(IEnumerable<int> input)
{
var timer = new Stopwatch();
timer.Start();
var size = input.Count();
if (input.AsParallel().
WithDegreeOfParallelism(10).
WithExecutionMode(ParallelExecutionMode.ForceParallelism).
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;
}
¿Cuántos procesadores/núcleos tiene? – LukeH
Dos. Pero especifiqué específicamente que el grado de paralelismo es 10. – ripper234
Si tiene una tarea enlazada de E/S y ejecutarla en múltiples hilos en paralelo mejora la velocidad, entonces probablemente no estaba realmente ligada a E/S, en primer lugar, estaba mal escrito (lecturas sincronizadas en lugar de asincrónicas, por ejemplo). –