У меня есть текстовый файл, содержащий URL различных каналов. Я читаю все URL в коллекции (IEnumerable), используя следующий код:
var URLs = File.ReadLines(Path.GetFullPath(@"Resources\FeedList.txt"));
В следующей строке я печатаю общее количество:
Console.WriteLine("Total Number of feeds : {0}",URLs.Count());
И после этого я использую конструкцию Parellel.ForEach для выполнения некоторой логики, соответствующей каждому URL. Ниже приведен код, который я использую:
Parallel.ForEach(URLs, (url) =>
{
// Some business logic
});
Проблема в том, что я получаю следующее исключение, как только добавляю код для печати номера URL-адреса, то есть кода, который вызывает метод Count () для объекта URL-адресов. Исключение:
Total Number of feeds : 78
Unhandled Exception: System.AggregateException: One or more errors occurred. ---> System.ObjectDisposedException: Cannot read from a closed TextReader.
at System.IO.__Error.ReaderClosed()
at System.IO.StreamReader.ReadLine()
at System.IO.File.<InternalReadLines>d__0.MoveNext()
at System.Collections.Concurrent.Partitioner.DynamicPartitionerForIEnumerable`1.InternalPartitionEnumerator.GrabNextChunk(Int32 requestedChunkSize)
at System.Collections.Concurrent.Partitioner.DynamicPartitionEnumerator_Abstract`2.MoveNext()
at System.Threading.Tasks.Parallel.<>c__DisplayClass32`2.<PartitionerForEachWorker>b__30()
at System.Threading.Tasks.Task.InnerInvoke()
at System.Threading.Tasks.Task.InnerInvokeWithArg(Task childTask)
at System.Threading.Tasks.Task.<>c__DisplayClass7.<ExecuteSelfReplicating>b__6(Object )
--- End of inner exception stack trace ---
at System.Threading.Tasks.Task.ThrowIfExceptional(Boolean includeTaskCanceledExceptions)
at System.Threading.Tasks.Task.Wait(Int32 millisecondsTimeout, CancellationToken cancellationToken)
at System.Threading.Tasks.Parallel.PartitionerForEachWorker[TSource,TLocal](Partitioner`1 source, ParallelOptions parallelOptions, Action`1 simpleBody, Action`2 bodyWi
at System.Threading.Tasks.Parallel.ForEachWorker[TSource,TLocal](IEnumerable`1 source, ParallelOptions parallelOptions, Action`1 body, Action`2 bodyWithState, Action`3
at System.Threading.Tasks.Parallel.ForEach[TSource](IEnumerable`1 source, Action`1 body)
at DiscoveringGroups.Program.Main(String[] args) in C:\Users\Pawan Mishra\Documents\Visual Studio 2010\Projects\ProgrammingCollectiveIntelligence\DiscoveringGroups\Pro
Press any key to continue . . .
И если я удаляю / закомментирую строку, которая печатает значение счетчика, цикл Parallel.ForEach работает нормально.
Кто-нибудь имеет представление о том, что здесь происходит не так?