Seguridad del hilo de retorno de rendimiento con Parallel.ForEach ()

Considere el siguiente ejemplo de código, que crea una colección enumerable de enteros y la procesa en paralelo:

using System.Collections.Generic;
using System.Threading.Tasks;

public class Program
{
    public static void Main()
    {
        Parallel.ForEach(CreateItems(100), item => ProcessItem(item));
    }

    private static IEnumerable<int> CreateItems(int count)
    {
        for (int i = 0; i < count; i++)
        {
            yield return i;
        }
    }

    private static void ProcessItem(int item)
    {
        // Do something
    }
}

¿Está garantizado que los hilos de trabajo generados porParallel.ForEach() cada uno obtiene un elemento diferente o es algún mecanismo de bloqueo alrededor de la incrementación y devolución dei ¿necesario?

Respuestas a la pregunta(2)

Su respuesta a la pregunta