最近看项目中有个地方用到了 List<Object> ,想到List<Object>能动态插入object对象,而ArrayList也是动态插入object对象。我在想这两个是不是同样的功能呢,查看元数据代码如下:

ArrayList

publicclassArrayList:IList,ICollection,IEnumerable,ICloneable

publicvirtualintAdd(objectvalue);//添加一个对象

List<T>

publicclassList<T>:IList<T>,ICollection<T>,IEnumerable<T>,IList,ICollection,IEnumerable

publicvoidAdd(Titem);//添加一个对象

比较两者,发现两者的Add方法一个是可重写的,并且返回当前索引,一个就是void方法,Titem,当T为Object的时候,个人认为两者差距不大,但是他们如果Add值类型的时候就会引发装箱操作,影响性能,通过测试发现(测试代码在附件中),ArrayList和List<Object>两者执行同样的操作,效率差不多,无论是有无拆装箱。但是,如果用到List<T>时候,最好不要把 T传入Object ,否则失去了泛型T的意义。如果执行int操作,就用List<int>.


总的来说呢,程序开发过程中尽量避免拆装箱的操作,频繁的拆装箱会使效率降低很多。

题外话:以前看面试题目,问到ArrayList和List的区别,感觉一头雾水,直到现在才明白,原来问的是这么个问题,唉,程序不能只写,也得思考啊,另外,F12看程序元数据也是不错的学习方法。附上程序运行结果,不过有偏差,如果单独运行ArrayList或者List<Object>它俩结果就相差不大,可是把List<Object>放在ArrayList后边运行,就会显得慢一些,估计也有程序问题吧,就到这了。以上纯属个人见解,如果错误,请不吝指出。


附件:http://down.51cto.com/data/2365203