zoukankan      html  css  js  c++  java
  • 浅谈 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

     

  • 相关阅读:
    HDU 5444 Elven Postman (2015 ACM/ICPC Asia Regional Changchun Online)
    POJ 1577 Falling Leaves 二叉搜索树
    HDU 3791 二叉搜索树
    Problem: Godfather 树的重心
    Problem: [Poi0202]Travelling Salesman 最近公共祖先
    Problem: 最优连通子集
    Problem: 扫雪系列II
    Problem: 扫雪系列I
    Problem: [Ural1039]没有上司的晚会
    Problem: 八中教室的灯
  • 原文地址:https://www.cnblogs.com/qinjian123/p/2536543.html
Copyright © 2011-2022 走看看