ArrayList通俗的理解,就是能创建动态数组,不需要初始化其大小。
-
这个类有三个构造函数:
一 : public ArrayList()
初始化 ArrayList类的新实例,该实例为空并且具有默认初始容量。
二:public ArrayList(ICollection)
初始化 ArrayList类的新实例,该实例包含从指定集合复制的元素并且具有与所复制的元素数相同的初始容量。
三:Public ArrayList(Int32)
初始化 ArrayList类的新实例,该实例为空并且具有指定的初始容量。
-
ArrayList的几个重要属性:
Count:获取ArrayList 中实际包含的元素数。
Capacity:获取或设置 ArryList可包含的元素数。
IsFixedSize:获取一个值,该值指示 ArrayList是否具有固定大小。
IsReadOnly:获取一个值,该值指示 ArrayList 是否为只读。
Item:获取或设置指定索引处的元素。
-
ArrayList的一些重要方法:
Add、AddRange、Remove、RemoveAt、RemoveRange、Insert、InsertRange
这几个方法比较类似
Add方法用于添加一个元素到当前列表的末尾
AddRange方法用于添加一批元素到当前列表的末尾
Remove方法用于删除一个元素,通过元素本身的引用来删除
RemoveAt方法用于删除一个元素,通过索引值来删除
RemoveRange用于删除一批元素,通过指定开始的索引和删除的数量来删除
Insert用于添加一个元素到指定位置,列表后面的元素依次往后移动
InsertRange用于从指定位置开始添加一批元素,列表后面的元素依次往后移动
另外,还有几个类似的方法:
Clear方法用于清除现有所有的元素
Contains方法用来查找某个对象在不在列表之中
ToArray:将 ArrayList的元素复制到新数组中
GetRange:返回 ArrayList,它表示源ArrayList 中元素的子集。
TrimToSize:将容量设置为 ArrayList中元素的实际数目。当动态数组元素确定不在添加的时候,可以调用这个方法来释放空余的内存。
ArrayList最佳使用建议:
这一节我们来讨论ArrayList与数组的差别,以及ArrayList的效率问题
(1)ArrayList是Array的复杂版本
ArrayList内部封装了一个Object类型的数组,从一般的意义来说,它和数组没有本质的差别,甚至于ArrayList的许多方法,如Index、IndexOf、Contains、Sort等都是在内部数组的基础上直接调用Array的对应方法。
(2)内部的Object类型的影响
对于一般的引用类型来说,这部分的影响不是很大,但是对于值类型来说,往ArrayList里面添加和修改元素,都会引起装箱和拆箱的操作,频繁的操作可能会影响一部分效率。
但是恰恰对于大多数人,多数的应用都是使用值类型的数组。
消除这个影响是没有办法的,除非你不用它,否则就要承担一部分的效率损失,不过这部分的损失不会很大。
(3)数组扩容
这是对ArrayList效率影响比较大的一个因素。
每当执行Add、AddRange、Insert、InsertRange等添加元素的方法,都会检查内部数组的容量是否不够了,如果是,它就会以当前容量的两倍来重新构建一个数组,将旧元素Copy到新数组中,然后丢弃旧数组,在这个临界点的扩容操作,应该来说是比较影响效率的。
例1:比如,一个可能有200个元素的数据动态添加到一个以默认16个元素大小创建的ArrayList中,将会经过:
16*2*2*2*2 = 256
四次的扩容才会满足最终的要求,那么如果一开始就以:
ArrayList List = new ArrayList( 210);
的方式创建ArrayList,不仅会减少4次数组创建和Copy的操作,还会减少内存使用。
例2:预计有30个元素而创建了一个ArrayList:
ArrayList List = new ArrayList(30);
在执行过程中,加入了31个元素,那么数组会扩充到60个元素的大小,而这时候不会有新的元素再增加进来,而且有没有调用TrimSize方法,那么就有1次扩容的操作,并且浪费了29个元素大小的空间。如果这时候,用:
ArrayList List = new ArrayList(40);
那么一切都解决了。
所以说,正确的预估可能的元素,并且在适当的时候调用TrimSize方法是提高ArrayList使用效率的重要途径。
(4)频繁的调用IndexOf、Contains等方法(Sort、BinarySearch等方法经过优化,不在此列)引起的效率损失
首先,我们要明确一点,ArrayList是动态数组,它不包括通过Key或者Value快速访问的算法,所以实际上调用IndexOf、Contains等方法是执行的简单的循环来查找元素,所以频繁的调用此类方法并不比你自己写循环并且稍作优化来的快,如果有这方面的要求,建议使用Hashtable或SortedList等键值对的集合。
MSDN 参考地址:http://msdn.microsoft.com/zh-cn/library/7x4b0a97(v=VS.80).aspx
Adapter | 为特定的 IList 创建 ArrayList 包装。 | |
Add | 将对象添加到 ArrayList 的结尾处。 | |
AddRange | 将 ICollection 的元素添加到ArrayList 的末尾。 | |
BinarySearch | 已重载。 使用对分检索算法在已排序的 ArrayList 或它的一部分中查找特定元素。 | |
Clear | 从 ArrayList 中移除所有元素。 | |
Clone | 创建 ArrayList 的浅表副本。 | |
Contains | 确定某元素是否在 ArrayList 中。 | |
CopyTo | 已重载。 将 ArrayList 或它的一部分复制到一维数组中。 | |
Equals | 已重载。 确定两个 Object 实例是否相等。 (从 Object 继承。) | |
FixedSize | 已重载。 返回具有固定大小的列表包装,其中的元素允许修改,但不允许添加或移除。 | |
GetEnumerator | 已重载。 返回循环访问 ArrayList 的枚举数。 | |
GetHashCode | 用作特定类型的哈希函数。GetHashCode适合在哈希算法和数据结构(如哈希表)中使用。 (从 Object 继承。) | |
GetRange | 返回 ArrayList,它表示源 ArrayList 中元素的子集。 | |
GetType | 获取当前实例的 Type。 (从 Object 继承。) | |
IndexOf | 已重载。 返回 ArrayList 或它的一部分中某个值的第一个匹配项的从零开始的索引。 | |
Insert | 将元素插入 ArrayList 的指定索引处。 | |
InsertRange | 将集合中的某个元素插入 ArrayList 的指定索引处。 | |
LastIndexOf | 已重载。 返回 ArrayList 或它的一部分中某个值的最后一个匹配项的从零开始的索引。 | |
ReadOnly | 已重载。 返回只读的列表包装。 | |
ReferenceEquals | 确定指定的 Object 实例是否是相同的实例。 (从 Object 继承。) | |
Remove | 从 ArrayList 中移除特定对象的第一个匹配项。 | |
RemoveAt | 移除 ArrayList 的指定索引处的元素。 | |
RemoveRange | 从 ArrayList 中移除一定范围的元素。 | |
Repeat | 返回 ArrayList,它的元素是指定值的副本。 | |
Reverse | 已重载。 将 ArrayList 或它的一部分中元素的顺序反转。 | |
SetRange | 将集合中的元素复制到 ArrayList 中一定范围的元素上。 | |
Sort | 已重载。 对 ArrayList 或它的一部分中的元素进行排序。 | |
Synchronized | 已重载。 返回同步的(线程安全)列表包装。 | |
ToArray | 已重载。 将 ArrayList 的元素复制到新数组中。 | |
ToString | 返回表示当前 Object 的 String。 (从 Object 继承。) | |
TrimToSize | 将容量设置为 ArrayList 中元素的实际数目。 |