0

我正在创建一个包含大量项目的数组(项目数> 2500)。该数组保存具有下面程序中描述的结构的对象。
我观察到该过程的“%Time 花在 GC 中”达到了一个很高的值。它从 value 开始ArraySize = 2500。对于低于 2500 的任何情况,在 GC 中花费的高 %time 具有低值。事实上,即使使用 ArraySize=2499,计数器也没有显示任何增加。

性能计数器:
在此处输入图像描述
代码:

namespace TestGC
{
    public class Line
    {
        private string _data1;
        private decimal _data2;
        private decimal _data3;

        public string Data1
        {
            get { return _data1; }
            set { _data1 = value; }
        }

        public decimal Data2
        {
            get { return _data2; }
            set { _data2 = value; }
        }

        public decimal Data3
        {
            get { return _data3; }
            set { _data3 = value; }
        }
        public Line()
        {
        }


    }


    public class Item
    {
        public const int Size = 200;
        private Line[] _lines = new Line[Size];

        public Line[] Lines
        {
            get { return _lines; }
            set { _lines = value; }
        }
    }

    public class Package
    {
        private Item _item;

        public Package()
        {
            _item = new Item();
            for (int i = 0; i < Item.Size; i++)
            {
                _item.Lines[i] = new Line();
            }
        }

        public Item Item
        {
            get { return _item; }
            set { _item = value; }
        }

    }

    class Program
    {
        private const int ArraySize = 2500;
        static Package[] array = new Package[ArraySize];
        static void Main(string[] args)
        {           
            Console.ReadLine();

            for (int i = 0; i < ArraySize; i++)
            {
                array[i] = new Package();
            }

            Console.ReadLine();
        }
    }
}
4

1 回答 1

-1

GC 可能正在重新分配周围的东西。这是一些预期的行为。我建议阅读有关大对象堆的内容。

于 2013-06-05T14:39:59.457 回答