您的位置:首页 > 其它

Array和Arraylist的应用辨析

2017-12-03 17:32 363 查看
这文章是我遇到一段代码,用ArrayList.toArray()方法,我搞不懂这样做的意义是什么,在网上查资料发现各种观点、资料都不是很完整,所以在此结合自己的理解,给出一个较完整的辨析说明,希望能帮助到大家。如有错误,欢迎批评指正。

一、Array和ArrayList变量的用法辨析

1. Array类型的变量在声明的同时必须进行实例化(至少得初始化数组的大小),而ArrayList可以只是先声明。
2. Array只能存储同构的对象,而ArrayList可以存储异构的对象。

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

而ArrayList可以存放任何不同类型的数据(因为它里面存放的都是被装箱了的Object型对象,实际上ArrayList内部就是使用

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

Array是始终是连续存放的,而ArrayList的存放不一定连续。
4 初始化大小

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

而ArrayList的大小可以动态指定,其大小可以在初始化时指定,也可以不指定,也就是说该对象的空间可以任意增加。
5 Array不能够随意添加和删除其中的项,而ArrayList可以在任意位置插入和删除项。

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

ArrayList的一些特性

ArrayList的capacity属性值会随ArrayList中的项的实际大小来发生改变

通过ArrayList类的TrimToResize()方法可以将ArrayList实例中的空项去除以压缩体积。

在C#2.0中,建议大家尽量使用范型版的ArrayList,即System.Collection.Generics命名空间下的List<T>,

这样不但保证了类型安全,而且由于没有了装箱和拆箱的过程,从而提高了对象处理的效率。

以上引用自:http://blog.csdn.net/yangwenxue_admin/article/details/44537175

二、关于ArrayList的toArray使用:

1:无参数的toArray使用

无参数的toArray会直接在toArray内部初始化一个大小与ArrayList相同数组并赋值返回。
2:有参数的toArray使用
当调用in=values.toArray(in);时候传入的in需要是一个初始化的数组(说法不是很准确,大概就是这个意思,不初始化会报错)

引用自

三、各自优缺点

ArrayList相对来说比较灵活,比如不需要先声明好长度。

在获取其中存储的数据时方法不同:ArrayList.get(i),Array[1]

此外还有Array中有一个sort()方法: (这个方法用处还挺多的,我猜这可能是为啥要转为Array的原因吧)

Object[] tempArray = temList.toArray();
Arrays.sort(tempArray);时间有点紧张,可能会不太准确,但是大方向总是没错的!富强 民主 文明 和谐 自由 平等 公正 法制 爱国 敬业 诚信 友善
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  arraylist 应用