ich eine sehr einfach Parallel.ForEach haben, dass der folgende Code ruft:C# Threading Parallel.ForEach und Directory Out of Memory Exception
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;
}
}
Das Problem ist, ich über genügend Arbeitsspeicher ausgeführt, dachte ich über GC.Collect() nach dem pjp.ProjectProcessor in der Parallel.ForEach, aber ich bin mir nicht sicher, ob dies funktioniert. Die Verzeichnisse sind extrem groß und ich bin nicht davon überzeugt, dass das Aufräumen viel hilft. Was wäre ein guter Weg, damit umzugehen?
Es hängt davon ab, was Sie mit den Dateien tun müssen. 'Directory.EnumerateFiles' könnte einen großen Unterschied machen. –
siehe bearbeiten, ich zähle nur die Größe der Verzeichnisse und der Dateianzahl, und Directory.EnumerateFiles verursacht ein großes Leistungsproblem –
Was genau soll Ihre Anwendung tun? Können Sie nicht zu einem Producer-Consumer-Modell wechseln und Ordner einzeln laden? – Tudor