C# ArrayList类的用法
来源:互联网 发布:html宣传源码 编辑:程序博客网 时间:2024/05/29 11:12
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
- C# ArrayList类的用法
- C# ArrayList的用法
- C# ArrayList的用法
- C# ArrayList的用法
- C# ArrayList的用法
- C# ArrayList的用法
- C# ArrayList的用法
- C# ArrayList的用法
- C# ArrayList的用法
- C#中ArrayList类的用法 - 工欲善其事必先利其器
- C#中ArrayList的用法
- C#之ArrayList 的用法
- ArrayList类的用法
- C#的ArrayList类
- C# Arraylist的sort函数的用法
- C# ArrayList 基本用法
- C# ArrayList用法
- C#中ArrayList用法小结
- 析构函数定义为虚函数原因
- 为什么在sql查询中需要使用xxx is null而不能使用xxx=null详解
- map和hash_map的比较
- Java初学习 - 自动拆装箱的说明
- mysql load data infile一则
- C# ArrayList类的用法
- iOS开发 Error: CGImageProviderCreate: invalid image provider size
- TCP/IP_socket_in_C笔记
- Action Bank A High-Level Representation of Activity in Video实验
- Android布局文件属性值
- 开源项目SlidingMenu深入剖析
- 关于dialog的一些
- Mat遍历,if and else if else
- Scrapy 爬虫