Segurança de thread de retorno de rendimento com Parallel.ForEach ()

Considere o exemplo de código a seguir, que cria uma coleção enumerável de números inteiros e os processa em 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
    }
}

É garantido que os threads de trabalho gerados porParallel.ForEach() cada um recebe um item diferente ou é algum mecanismo de bloqueio em torno de incrementação e retorno dei requeridos?

questionAnswers(2)

yourAnswerToTheQuestion