Vector和ArrayList比较
Vector和ArrayList 都是对List接口的实现类,实现对数组(数据以数组的形式保存)的动态修改。
两者比较建议使用ArrayList,下面对这两种类型的比较。存在即合理,如果以后发现使用Vector优于ArrayList的再进行补充。
-
网上很多资料指出Vector是线程安全的。查看源码目前发现提现在两方面
1)Vector中的方法很多是synchronized的,例如
- -public synchronized boolean add(E e) // 添加项
- -public synchronized E remove(int index)//删除项
2)在进行迭代的时候添加了添加了锁
- -synchronized (Vector.this)
如果有需要我们完全可以通过代码控制同步,而不是所有对数组更改都进行同步控制,目前已知synchronized效率低,以后对synchronized的原理进行学习 -
增量大小不同(数组到达上限后增加空间的大小)。Vector可以按指定的大小进行扩充,默认是当前数组大小。ArrayList默认是当前数组的一半。



博客主要对Vector和ArrayList进行比较,二者都是List接口实现类,可动态修改数组。建议优先使用ArrayList,Vector是线程安全的,体现在方法加synchronized和迭代时加锁,但可通过代码控制同步。此外,二者增量大小不同,Vector默认按当前数组大小扩充,ArrayList默认是当前数组一半。

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



