浅谈:ArrayList,List<T>,List<Object>
最近看项目中有个地方用到了 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后边运行,就会显得慢一些,估计也有程序问题吧,就到这了。以上纯属个人见解,如果错误,请不吝指出。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。