相信数组是大家在编程最常使用的不论任何语言都存在数组这样的数据结构由于C#语言是完全面向对象的所以在C#中的数组也是对象不论任何语言都存在数组这样的数据结构由于C#语言是
public static void Main(string[] args)
{
ArrayList myList new ArrayList(2);
Console.WriteLine("initial capacity:" myList.Capacity);
int size 2;
for (int i 0; i < size;i )
{
myList.Add(i);
}
Console.WriteLine("current capacity:" myList.Capacity);
Console.ReadLine();
}
当size为2时输出结果中的"current capacity"为2当size为3或4时"current capacity"为4当size为5~8时"current capacity"为8,当size为9~16时"current capacity"为16,...通过实验可以得出一个结论那就是每当ArrayList中的实际存在的对象数 (ArrayList.Count)超过了自身的Capacity阀值那么该阀值会自动翻倍。 (也可以改变myList生成时的初始值来试 试但结论是一样的) #2 通过ArrayList类的TrimToResize()方法可以将ArrayList实例中的空项去除以压缩体积。如以下代码
public static void Main(string[] args)
{
ArrayList myList new ArrayList(5);
for (int i 0; i < 3; i)
{
myList.Add(i);
}
Console.WriteLine("actual capacity:" myList.Capacity);
myList.TrimToSize();
Console.WriteLine("compressed capacity:" myList.Capacity);
Console.ReadLine();
}
输出actual capacity:5compressed capacity:3 #3 在C#2.0中建议大家尽量使用范型版的ArrayList即System.Collection.Generics命名空间下的 List这样不但保证了类型安全而且由于没有了装箱和拆箱的过程从而提高了对象处理的效率。 转:https://blog.51cto.com/mslagee/328905
