我正在创建一个包含大量项目的数组(项目数> 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();
}
}
}