数组,arrayList和List

Posted mcyushao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数组,arrayList和List相关的知识,希望对你有一定的参考价值。

数组,arrayList和List

      (1)数组在C#中是最早出现的。它在内存中是连续的存储的,所以索引速度很快,而且赋值与修改元素也很简单。可以利用偏移地址访问元素,时间复杂度为O(1);可以用折半查找法查找元素,效率高。

          数组也有很多缺点。数组分配在一块连续的数据空间上,因此分配空间时必须确定大小。空间的连续,也导致了存储效率低,插入和删除元素效率比较低,而且麻烦。如果,要增添一个元素,需要移动大量元素,在内存中空出一个元素的空间,然后将要增加的元素放在其中。同样,你想删除一个元素,需要移动大量元素去填补被移动的元素。

还有我们在声明数组的时候,必须同时指明数组的长度,数组的长度过长,会造成内存浪费,数组和长度过短,会造成数据溢出的错误。这样如果在声明数组时我们并不清楚数组的长度,就变的很棘手了。

(2)arrayList它的大小是按照其中存储的数据来动态扩充与收缩的。所以,我们在声明ArrayList对象时并不需要指定它的长度。ArrayList继承了IList接口,所以它可以很方便的进行数据的添加

缺点:内部的存储数组时object类型的。存储不同类型的时候会发生装箱和拆箱,耗费性能。

    (3)List的大部分用法都与ArrayList相似,因为List类也继承了IList接口。最关键的区别在于,在声明List集合时,我们同时需要为其声明List集合内数据的对象类型。

以上是关于数组,arrayList和List的主要内容,如果未能解决你的问题,请参考以下文章

java arraylist怎么转化成数组

C#中数组ArrayList和List三者的区别

java中二维数组和ArrayList的相互转换

.数组和ArrayList

Java的数组和ArrayList

ArrayList