为什么我应该在DataContainer或DataContext上调用Dispose,而它似乎没有区别?

时间:2011-08-12 15:50:08

标签: performance entity-framework memory disposable data-containers

我创建了一个简单的测试程序,以找出调用Dispose与不为DataContainer对象调用它之间的内存和速度差异。

这是我的测试程序:

static void Main(string[] args)
{
    Stopwatch stopwatch = new Stopwatch();
    stopwatch.Start();

    for (int i = 0; i < 5000; i++)
    {
        // I change the following call with Method1 and run it again
        var res = Method2();
        int count = res.Count;
    }

    stopwatch.Stop();
    Console.WriteLine(stopwatch.Elapsed);
    Console.WriteLine("Mem: " + System.Diagnostics.Process.GetCurrentProcess().PrivateMemorySize64.ToString("N"));
    Console.ReadKey();
}

private static IList Method1()
{
    using (var db = new Model.SampleEntities())
    {
        var result = db.People.Where(p => p.Name.StartsWith("a")).Take(1);
        return result.ToList();
    }
}

private static IList Method2()
{
    var db = new Model.SampleEntities();
    var result = db.People.Where(p => p.Name.StartsWith("a")).Take(1);
    return result.ToList();
}

两种方法的结果相同。 我的PC上的结果大约是27.22秒,私有内存大小约为37.7 MB。

现在我为什么要在没有差异的情况下调用Dispose for DataContainers?

提前致谢。

1 个答案:

答案 0 :(得分:0)

我想想Model.SampleEntities有充分理由返回IDisposable - perhas正确清理托管和/或非托管资源等