Array和ArrayList的异同点

原创 2006年06月09日 17:58:00

相信数组是大家在编程最常使用的,不论任何语言都存在数组这样的数据结构,由于C#语言是完全面向对象的,所以在C#中的数组也是对象,
实际上就是Array类的实例,Array类的使用可以说是使用最频繁的,只是大家在使用时都没太在意,如在创建数组int[]时实际上就创建了一个Array类对象的实例。
最近我仔细研究了一下C#中的Array及ArrayList类之间的异同,总结了以下几点:

[Array和ArrayList的区别]

#1. Array类型的变量在声明的同时必须进行实例化(至少得初始化数组的大小),而ArrayList可以只是先声明。
如:
 int[] array = new array[3];
 或 int[] array = {1,2,3};
 或 ArrayList myList = new ArrayList();
这些都是合法的,而直接使用 int[] array;是不行的。

#2. Array只能存储同构的对象,而ArrayList可以存储异构的对象。
同构的对象是指类型相同的对象,若声明为int[]的数组就只能存放整形数据,string[]只能存放字符型数据,但声明为object[]的数组除外。
而ArrayList可以存放任何不同类型的数据(因为它里面存放的都是被装箱了的Object型对象,实际上ArrayList内部就是使用"object[] _items;"这样一个私有字段来封装对象的)

#3 在CLR托管对中的存放方式
Array是始终是连续存放的,而ArrayList的存放不一定连续。

#4 初始化大小
Array对象的初始化必须只定指定大小,且创建后的数组大小是固定的,
而ArrayList的大小可以动态指定,其大小可以在初始化时指定,也可以不指定,也就是说该对象的空间可以任意增加。

#5 Array不能够随意添加和删除其中的项,而ArrayList可以在任意位置插入和删除项。


[Array和ArrayList的相似点]

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


[ArrayList的一些特性]

#1 在研究ArrayList我发现了一个有趣的现象,ArrayList的capacity属性值会随ArrayList中的项的实际大小来发生改变,
如下代码:

public static void Main(string[] args)
        
{
            ArrayList myList 
= new ArrayList(2);
            Console.WriteLine(
"initial capacity:" + myList.Capacity);

            
int size = 2;
            
for (int i = 0; i < size;i++ )
            
{
                myList.Add(i);
            }

            Console.WriteLine(
"current capacity:" + myList.Capacity);
            
            Console.ReadLine();
        }

当size为2时,输出结果中的"current capacity"为2,
当size为3或4时,"current capacity"为4,
当size为5~8时,"current capacity"为8,
当size为9~16时,"current capacity"为16,
...
通过实验可以得出一个结论,那就是每当ArrayList中的实际存在的对象数(ArrayList.Count)超过了自身的Capacity阀值,那么该阀值会自动翻倍。
(也可以改变myList生成时的初始值来试试,但结论是一样的)

#2 通过ArrayList类的TrimToResize()方法可以将ArrayList实例中的空项去除以压缩体积。
如以下代码:

public static void Main(string[] args)
        
{
            ArrayList myList 
= new ArrayList(5);

            
for (int i = 0; i < 3; i++)
            
{
                myList.Add(i);
            }

            Console.WriteLine(
"actual capacity:" + myList.Capacity);
            myList.TrimToSize();
            Console.WriteLine(
"compressed capacity:" + myList.Capacity);
            
            Console.ReadLine();
        }

输出:
actual capacity:5
compressed capacity:3

#3 在C#2.0中,建议大家尽量使用范型版的ArrayList,即System.Collection.Generics命名空间下的List<T>,
这样不但保证了类型安全,而且由于没有了装箱和拆箱的过程,从而提高了对象处理的效率。

相关文章推荐

.net(c#)中Array和ArrayList的异同点

【摘要】 在C#中的数组也是对象,实际上就是Array类的实例,Array类的使用可以说是使用最频繁的,只是大家在使用时都没太在意,如在创建数组int[]时实际上就创建了一个Array类对象的实例。...

Array和ArrayList的异同点

相信数组是大家在编程最常使用的,不论任何语言都存在数组这样的数据结构,由于C#语言是完全面向对象的,所以在C#中的数组也是对象, 实际上就是Array类的实例,Array类的使用可以说是使用最频繁的...

Java进阶(四十六)简述ArrayList、Vector与LinkedList的异同点

简述ArrayList、Vector与LinkedList的异同点  Collection类的继承图如下:   从图中可以看出,LinkedList与ArrayList、ArrayDeque这三者都...

C# Array和ArrayList,List区别

  • 2011年12月17日 01:28
  • 274KB
  • 下载

Vector、ArrayList和List的异同[转载]

http://www.blogjava.net/yanzhicun/articles/178799.html 线性表,链表,哈希表是常用的数据结构,在进行Java开发时,JDK已经为我们提供了一系列...
  • Lyncai
  • Lyncai
  • 2012年07月10日 15:09
  • 447

Vector、ArrayList和hashtable、hashmap的异同

本文转自 http://ludaojuan21.iteye.com/blog/243411 线性表,链表,哈希表是常用的数据结构,在进行Java开发时,JDK已经为我们提供了一系列相应的类来实现基本...

ArrayList与Vector异同

List是一个接口,里面声明有操作“表”这一种数据结构的通用方法,具体实现类实现此接口后,根据实现的不同可对通用方法进行不同程度的扩展,它主要有四个实现类:ArrayList,LinkedList,V...

Vector、ArrayList和List的异同

线性表,链表,哈希表是常用的数据结构,在进行Java开发时,JDK已经为我们提供了一系列相应的类来实现基本的数据结构。这些类均在java.util包中。本文试图通过简单的描述,向读者阐述各个类的作用以...

ArrayList和Vector的异同

这两个类都实现了List接口(List接口继承了Collection接口),他们都是有序集合,即存储在这两个集合中的元素的位置都是有顺序的,相当于一种动态的数组,我们以后可以按位置索引号取出某个元素,...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Array和ArrayList的异同点
举报原因:
原因补充:

(最多只允许输入30个字)