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。