Java集合-ArrayList与Vector的区别
1、ArrayList与Vector的底层代码
首先先看ArrayList的底层代码。如图所示:

1.实现了List接口,可以存放空元素、重复元素,元素之间存放的顺序是有序的。
2.实现了RandomAccess接口,RandomAccess接口的作用是用来标记,可以快速随机访问。
3.实现了Serializable接口,支持序列化,可以通过序列化传输。
4.实行了Cloneable接口,能被克隆。
Vector的实现接口与ArrayList一致。如图所示:

2、ArrayList与Vector的相同点
1.都是动态数组,可以自动扩容。
2.可以存放null和重复元素,存放的元素是有序的。
3.能够快速随机访问对象。
4.都能被克隆
5.支持序列化,可以通过序列化进行传输。
3、ArrayList与Vector的不相同点
1.Vector方法都是同步的,所以是线程安全的,ArrayList则不是。线程同步会影响性能,所以ArrayList性能要比Vector好。2.ArrayList或Vector的元素超过他的默认初始容量,ArrayList会扩容50%,而Vector会翻倍。这样ArrayList会更省内存。
总结:
如果在开发中涉及到线程安全可以用Vector,其他情况都用ArrayList。

本文探讨了Java集合中ArrayList与Vector的异同。两者均为动态数组,支持快速随机访问及序列化,但Vector方法同步,适合多线程环境,而ArrayList性能更优且内存使用更高效。
1579

被折叠的 条评论
为什么被折叠?



