最近看项目中有个地方用到了 List<Object> ,想到List<Object>能动态插入 object对象,而ArrayList也是动态插入object对象。我在想这两个是不是同样的功能呢,查看元数据代码如下:
ArrayList
public class ArrayList : IList, ICollection, IEnumerable, ICloneable
public virtual int Add(object value);//添加一个对象
List<T>
public class List<T> : IList<T>, ICollection<T>, IEnumerable<T>, IList, ICollection, IEnumerable
public void Add(T item);//添加一个对象
比较两者,发现两者的Add方法一个是可重写的,并且返回当前索引,一个就是void 方法,T item,当T为Object的时候,个人认为两者差距不大,但是他们如果Add 值类型的时候就会引发装箱操作,影响性能,通过测试发现(测试代码在附件中),ArrayList 和List<Object> 两者执行同样的操作,效率差不多,无论是有无拆装箱。但是,如果用到List<T> 时候,最好不要把 T 传入Object ,否则失去了泛型T 的意义。如果执行int操作,就用List<int>.
总的来说呢,程序开发过程中尽量避免拆装箱的操作,频繁的拆装箱会使效率降低很多。
题外话:以前看面试题目,问到ArrayList和List的区别,感觉一头雾水,直到现在才明白,原来问的是这么个问题,唉,程序不能只写,也得思考啊,另外,F12看程序元数据也是不错的学习方法。附上程序运行结果,不过有偏差,如果单独运行ArrayList 或者List<Object> 它俩结果就相差不大,可是把List<Object>放在ArrayList后边运行,就会显得慢一些,估计也有程序问题吧,就到这了。以上纯属个人见解,如果错误,请不吝指出。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。