欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C# 中 Array和 ArrayList详解及区别

程序员文章站 2022-07-06 11:05:59
c# 中 array和 arraylist详解及区别 一、array 的用法 type[] typename=new type[size]; &n...

c# 中 array和 arraylist详解及区别

一、array 的用法

  type[]  typename=new type[size]; 

  或者  

 type[]  typename=new type[]{ }; 

 array类型的变量在声明的同时必须进行实例化(如果初始化至少得初始化数组的大小)

 平常我们int[],string[]...事实上就是声明一个array数组了

   如:

 string [] srt=new string[]{"a","b"};

     int[] a=new int[2]; string [] srt=new string[3];

(1):type数据类型不能缺;且要统一,而不能是如 int[] a=new array[];

(2):数组的大小size不能缺,否则c#认为是出错的,因为数组是一段固定长度的内存;

(3):右边是一个中括号[],而不是()

注:array数组并不提供add,clear,addrange..方法,而是直接设置或获取值

如:a[0] = 0;  a[1] = 1;

二,c# arraylist数组的用法:

var arraylist = new arraylist();

      arraylist.add(1);
      arraylist.add(2);
      arraylist.add(50.0); //在.net 4.0 支持。具体为什么还没有研究 
      foreach (var array in arraylist)
      {
        console.writeline(array);
      }

三,arraylist和array相互之间的转化

 var arraylist = new list<int>();
      arraylist.add(1);
      arraylist.add(2);
      arraylist.add(50);

      //arraylist 数组中的值拷贝到array中去
      int[] array1=new int[arraylist.count];
      arraylist.copyto(array1); //方法一
      int[] array2 = arraylist.toarray(); //方法二

四、[array和arraylist的区别]

#1. array类型的变量在声明的同时必须进行实例化(至少得初始化数组的大小),而arraylist可以只是先声明。

如: 

int[] array = new array[3];
 或 int[] array = {1,2,3};
 或 arraylist mylist = new arraylist();

这些都是合法的,而直接使用 int[] array;是不行的。

#2. array只能存储同构的对象,而arraylist可以存储异构的对象。

同构的对象是指类型相同的对象,若声明为int[]的数组就只能存放整形数据,string[]只能存放字符型数据,但声明为object[]的数组除外。

而arraylist可以存放任何不同类型的数据(因为它里面存放的都是被装箱了的object型对象,实际上arraylist内部就是使用"object[] _items;"这样一个私有字段来封装对象的)

#3 在clr托管对中的存放方式

array是始终是连续存放的,而arraylist的存放不一定连续。

#4 初始化大小

array对象的初始化必须只定指定大小,且创建后的数组大小是固定的,

而arraylist的大小可以动态指定,其大小可以在初始化时指定,也可以不指定,也就是说该对象的空间可以任意增加。

#5 array不能够随意添加和删除其中的项,而arraylist可以在任意位置插入和删除项。

五、[array和arraylist的相似点]

#1 都具有索引(index),即可以通过index来直接获取和修改任意项。
#2 他们所创建的对象都放在托管堆中。
#3 都能够对自身进行枚举(因为都实现了ienumerable接口)。

六 、[arraylist的一些特性]

var arraylist = new list<int>(2);
 console.writeline(arraylist.capacity);
      
      int size = 2;
      for (int i = 0; i < size; i++)
      {
        arraylist.add(i);
      }
   
      console.writeline("compressed capacity:"+arraylist.capacity); 

当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阀值,那么该阀值会自动翻倍

 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:5
compressed capacity:3

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!