zoukankan      html  css  js  c++  java
  • Array与ArrayList

    1. Array

    public abstract class Array : ICloneable, IList, ICollection, IEnumerable, IStructuralComparable, IStructuralEquatable

    {

    //////////////////

    }

    Array:长度是不变的(定长),里面的数据元素是同类型的,可以说Array是同一种数据类型的集合

    eg:

    Int32[] array = new Int32[5];

    Int32[] array = new Int32[] { 2, 3, 4 };//会根据初始化器中数据元素个数来确定该数组的大小

    2. ArrayList

    public class ArrayList : IList, ICollection, IEnumerable, ICloneable

    {

    //////////////

    }

    长度是可以动态改变的,里面的数据元素可以是不同类型(值类型、引用类型),可以说ArrayList 可以是多种数据类型的集合

     ArrayList arrlist = new ArrayList();

    //通过下面这两个方法添加/删除元素,动态改变长度,这两个方法的参数都是object类型,如果向其传入的参数是值类型(ValueType)的话,会发生装箱(boxing)操作,运行比较慢,有损性能,

    eg:

    public virtual int Add(object value);  

    public virtual void Remove(object obj);

    3. List<T>

    public class List<T> : IList<T>, ICollection<T>, IEnumerable<T>, IList, ICollection, IEnumerable

    {

    //////////////

    }

    是ArrayList类的泛型等效类并增强了功能,通过以下两个方法添加/删除元素,动态改变长度,这两个方法的参数都是泛型类型,不会发生装箱(boxing)操作,所以List<T>在.NET 2.0以上可以完全代替ArrayList,且应该多用List<T>

    eg: 

    public void Add(T item);

    public bool Remove(T item);

    ----------另外,继承自IEnumberable接口(或IEnumerable <T>泛型接口)的类型都是可枚举的,也就是可以用foreach来遍历集合中的每一个元素

  • 相关阅读:
    现代操作系统-读者/写者问题
    现代操作系统-进程互斥
    关于网页强制被跳转到wpkg.org的解决
    Leetcode Count Prime
    Leetcode Add Two Numbers
    Leetcode Two Sum
    can't find -lsocket的解决办法
    删除Windows右键不用的选项
    Linux下的另一个词典GoldenDict
    spark执行例子eclipse maven打包jar
  • 原文地址:https://www.cnblogs.com/notebook2011/p/2783992.html
Copyright © 2011-2022 走看看