Я использую приведенный ниже код
var processed = new List<Guid>();
Parallel.ForEach(items, item =>
{
processed.Add(SomeProcessingFunc(item));
});
Является ли приведенный выше код потокобезопасным? Есть ли вероятность того, что обработанный список будет поврежден? Или стоит перед добавлением использовать блокировку?
var processed = new List<Guid>();
Parallel.ForEach(items, item =>
{
lock(items.SyncRoot)
processed.Add(SomeProcessingFunc(item));
});
благодаря.