你的位置:首页 > 软件开发 > ASP.net > C#中大List的内存分配

C#中大List的内存分配

发布时间:2016-03-28 11:00:16
之前在开发中只用到List的时候几乎就是拿过来就用,从来没有考虑过List的内存分配问题,试想一个有10万元素的List的在构造和添加元素时内存是如何变化的呢?在MSDN上关于List的Capacity属性是这么解释的,也就是说,当我们添加的元素数量小于等于Capacity的值时 ...

之前在开发中只用到List的时候几乎就是拿过来就用,从来没有考虑过List的内存分配问题,试想一个有10万元素的List的在构造和添加元素时内存是如何变化的呢?在MSDN上关于List的Capacity属性是这么解释的C#中大List的内存分配,也就是说,当我们添加的元素数量小于等于Capacity的值时,List是不会重新调整内部数据结构,也就是不会重新申请或者分配内存,而当我们添加的元素数量大于Capacity 的值时,List就会不断的调整内部数据结构或者重新申请分配内存,这样的话对效率肯定会有一定的影响的。

当我们使用List<T> list = new List<T>();实例化一个List对象是,.Net Framework只是在内存中申请了一块内存在存放list对象本身,系统此时并不知道list会有多少item元素。当我们向list添加第一个item时,list会申请能存储4个Item元素的存储空间,此时Capacity是4,但是当我们添加到第五个item时,此时的Capacity就会变成8,也就是当list发现元素的总数大于Capacity数量时,会主动申请并重新分配内存,当我们添加到第九个item时,Capacity不是12而是16,也就是说list每次申请的内存数量都是之前item元素数量两倍。然后将当前所有的item元素系但添加的元素复制到新的内存。

大家可以看到,如果list需要添加的元素特别多时,list会不断地申请心内存,复制已有元素和新加元素到新内存,这个过程会产生资源的浪费及性能问题。

如果当设置的Capacity值远大于list的实际元素数量时,应使用TrimExcess()方法释放点未使用的内存。

class Program  {    static void Main(get='_blank'>string[] args)    {      List<Part> parts = new List<Part>();      Console.WriteLine("\nCapacity: {0}", parts.Capacity);      parts.Add(new Part() { PartName = "crank arm", PartId = 1234 });      parts.Add(new Part() { PartName = "chain ring", PartId = 1334 });      parts.Add(new Part() { PartName = "seat", PartId = 1434 });      parts.Add(new Part() { PartName = "cassette", PartId = 1534 });      parts.Add(new Part() { PartName = "shift lever", PartId = 1634 });      Console.WriteLine();      foreach (Part aPart in parts)      {        Console.WriteLine(aPart);      }      Console.WriteLine("\nCapacity: {0}", parts.Capacity);      Console.WriteLine("Count: {0}", parts.Count);      parts.TrimExcess();      Console.WriteLine("\nTrimExcess()");      Console.WriteLine("Capacity: {0}", parts.Capacity);      Console.WriteLine("Count: {0}", parts.Count);      parts.Clear();      Console.WriteLine("\nClear()");      Console.WriteLine("Capacity: {0}", parts.Capacity);      Console.WriteLine("Count: {0}", parts.Count);      Console.Read();    }  }  public class Part  {    public string PartName { get; set; }    public int PartId { get; set; }    public override string ToString()    {      return "ID: " + PartId + "  Name: " + PartName;    }  }

 

海外公司注册、海外银行开户、跨境平台代入驻、VAT、EPR等知识和在线办理:https://www.xlkjsw.com

原标题:C#中大List的内存分配

关键词:C#

C#
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

可能感兴趣文章

我的浏览记录