【发布时间】:2012-09-02 09:18:49
【问题描述】:
我有一个线程,称之为“解析线程”。
Thread parsingThread = new Thread(myMethod);
我在这个线程上执行了一些计算,其中最后一个涉及更多的并行计算。
public void ReadCityFiles(BlockingCollection<GeonamesFileInfo> files)
{
Parallel.ForEach<GeonamesFileInfo>(
files.GetConsumingPartitioner<GeonamesFileInfo>(),
new ParallelOptions { MaxDegreeOfParallelism = _maxParallelism },
(inputFile, args) =>
{
RaiseFileParsing(inputFile);
using (var input = new System.IO.StreamReader(inputFile.FullName))
{
while (!input.EndOfStream)
{
RaiseEntryParsed(ParseCity(input.ReadLine()));
Interlocked.Increment(ref _parsedEntries);
}
}
RaiseFileParsed(inputFile);
});
RaiseDirectoryParsed(Directory);
}
问题在于,当这些非常长且计算量大的异步 foreach 操作完成(约 30 分钟)时,“解析线程”不会恢复。我的 GUI 仍然响应,但是应该继续在“解析线程”上运行的 RaiseDirectoryParsed 函数从未被调用。到目前为止,我已经调试了程序,但对于在这种情况下该怎么做感到非常困惑。
【问题讨论】:
-
RaiseDirectoryParsed 是做什么的,“解析线程”是做什么的?
-
Parellel.ForEach任务中很可能没有正确终止。您是否使用了一些控制台消息来确定这一点? -
引发解析线程处理的事件。无论如何它永远不会运行,在parallel.foreach之后执行停止,就好像解析线程永远不会恢复一样。
-
都铎王朝,说得好。如果任务的堆栈跟踪显示为外部代码,我该如何检查?
-
@Francisco Aguilera:只需在任务代码末尾添加
Console.WriteLine。查看所有任务是否最终终止。我猜他们不会。
标签: c# multithreading parallel.foreach