[英]C# Threading Parallel.ForEach and DirectoryInfo Out of Memory Exception
我有一個非常簡單的Parallel.ForEach,它調用以下代碼:
var maxDegree = new ParallelOptions{MaxDegreeOfParallelism = 5};
Parallel.ForEach(PList,maxDegree,fl =>
{
ProjectDirectoryProcessing pjp = new ProjectDirectoryProcessing();
pjp.ProjectProcessor(fl);
Console.ReadLine();
}
);
public class ProjectDirectoryProcessing
{
public void ProjectProcessor(string rootDirectory)
{
DirectoryInfo Dinfo = new DirectoryInfo(rootDirectory);
DirectoryInfo[] directories = Dinfo.GetDirectories("*.*", SearchOption.AllDirectories);
FileInfo[] finfo = Dinfo.GetFiles("*.*", SearchOption.AllDirectories);
foreach (FileInfo f in finfo)
{
FileSize = FileSize + f.Length;
}
FileCount = finfo.Length;
DirectoryCount = directories.Length;
}
}
問題是我內存不足,我在Parallel.ForEach中的pjp.ProjectProcessor之后想到了GC.Collect(),但是我不確定這是否可以工作。 目錄非常大,我不太肯定清理這些目錄會起到很大的作用。 什么是處理此問題的好方法?
手動調用GC將無濟於事,因為應該在引發OutOfMemoryException之前自動調用GC。 一種簡單的解決方案是將應用程序編譯為x64。 這是一個選擇嗎?
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.