¿Por qué PLINQ usa solo dos hilos?

Digamos que tengo una tarea vinculada a IO. Estoy usando WithDegreeOfParallelism = 10 y WithExecution = ForceParallelism, pero la consulta solo usa dos subprocesos. ¿Por qué?

Entiendo que, por lo general, PLINQ elegirá un grado de paralelismo igual a mi recuento central, pero ¿por qué ignora mi solicitud específica de un paralelismo superior?

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;
}

Respuestas a la pregunta(4)

Su respuesta a la pregunta