我正在尝试运行此方法,它工作正常,但每次经过数百次内部迭代后,我都会遇到内存不足异常:
...
MNDBEntities db = new MNDBEntities();
var regs = new List<DOCUMENTS>();
var query = from reg in db.DOCUMENTS
where reg.TAG_KEYS.Any(p => p.TAG_DATE_VALUES.FirstOrDefault().TAG_DATE_VALUE.HasValue
&& p.TAG_DATE_VALUES.FirstOrDefault().TAG_DATE_VALUE.Value.Year == 2012)
select reg;
var pages = new List<string>();
foreach (var item in query)
{
Document cert = new Document();
var tags = item.TAG_KEYS;
foreach (var tag in tags)
{
// Basic stuff...
}
var pagesS = item.PAGES;
foreach (var page in pagesS)
{
var path = @"C:\Kumquat\" + (int)page.NUMBER + ".vpimg";
File.WriteAllBytes(path, page.IMAGE);
pages.Add(path);
Console.WriteLine(path);
}
//cms.Save(cert, pages.ToArray()).Wait();
foreach (var pageFile in pages)
File.Delete(pageFile);
pagesS = null;
pages.Clear();
}
...
我很确定问题与 File.WriteAllBytes 或 File.Delete 有关,因为如果我评论这些行,该方法将毫无例外地运行。我所做的基本上是从数据库和文档图像中获取一些标签,然后将该图像保存到磁盘上,然后存储到 cms 中,然后从磁盘中删除。老实说,不知道我对 File 调用做错了什么。任何的想法?
这是 PerfView 显示的内容:
这就是 Visual Studio 2012 Profiler 显示的热点,问题是:这是所有生成的代码(在实体模型中)我做错了什么可能是模型的属性吗?