7

这张照片中的【垃圾收集】是什么意思?还有“20个电话”的事情?

我的意思是,我怎样才能弄清楚为什么 GC 花了这么长时间?是不是收集了很多小物件?一个大的?关于如何优化它的任何提示?

有问题的代码是:

private void DeserializeFrom(SerializationInfo info)
{
    Width = info.GetInt32("width");
    Height = info.GetInt32("height");
    var data = (List<byte>)info.GetValue("cells", typeof(List<byte>));
    cells = new Cell[physicalSize.Width, physicalSize.Height];
    int pos = 0;
    for (int x = 0; x < physicalSize.Width; x++)
    {
        for (int y = 0; y < physicalSize.Height; y++)
        {
            cells[x, y] = new Cell();
            if (x < Width && y < Height)
            {
                cells[x, y].HasCar = data[pos];
                pos++;
            }
        }
    }
}

没什么太花哨的。我怀疑罪魁祸首是大List<byte>物体,但我认为收集一个物体应该是即时的(而不是收集一堆小物体)。

4

2 回答 2

2

如果您想找出导致 GC 的原因、正在分配和收集的对象,您可以通过 dotMemory 来完成。这是一个解释如何优化内存流量的教程:https ://confluence.jetbrains.com/display/NETCOM/Tutorial+3+-+How+to+Optimize+Memory+Traffic+with+dotMemory

于 2015-02-23T14:27:44.857 回答
1

聚会有点晚了,但是如果您使用的是 .Net,那么您使用的是托管代码,这基本上意味着 .Net 运行时会相应地处理您的对象,因此与 C 或 C++ 相比,您不会出现内存泄漏。

垃圾收集是指运行时需要时间来管理应用程序的内存分配和释放。在这种情况下,这就是正在发生的事情。

请看一下这个可以与 doTrace 一起使用的过滤器(我有版本 6),以便您可以分析垃圾收集并确定它何时可能会阻止您的执行。 https://www.jetbrains.com/profiler/help/CLR_Activity.html

于 2015-02-09T18:57:30.387 回答