2

我正在尝试运行此方法,它工作正常,但每次经过数百次内部迭代后,我都会遇到内存不足异常:

...
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 显示的内容:

PerfView 的方法

这就是 Visual Studio 2012 Profiler 显示的热点,问题是:这是所有生成的代码(在实体模型中)我做错了什么可能是模型的属性吗?

在此处输入图像描述

4

1 回答 1

2

尝试使用http://www.microsoft.com/en-us/download/details.aspx?id=28567来分析您的代码,重点关注 GC 事件和 CLR 管理的分配滴答事件。

page.IMAGE 可能是问题所在。它很可能会分配一个字节数组并且永远不会删除它。最好将代码更改为:

page.WriteTo(path);

显示的其余代码看起来确实不错。唯一可能的问题是大对象分配,这可能导致LOH中的碎片问题。

于 2012-08-30T21:54:12.560 回答