java笔记--零碎--Vector和ArrayList
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默认是当前数组的一半。