Да;List<T>
не является потокобезопасным, поэтому добавление к нему произвольных потоков из произвольных потоков (вполне возможно, в то же время) обречено.Вместо этого вы должны использовать потокобезопасный список или добавить блокировку вручную.Или, может быть, есть Parallel.ToList
.
Также, если это имеет значение: порядок вставки не гарантируется.
Эта версия безопасна , хотя:
var output = new string[data.Count];
Parallel.ForEach<String>(data, (line,state,index) =>
{
String outputLine = index.ToString();
// ** Do something with "line" and store result in "outputLine" **
// Additionally, there are some this.Invoke statements for updating UI
output[index] = outputLine;
});
здесь мы используем index
для обновления другого индекса массива для параллельного вызова.