java笔记--零碎--Vector和ArrayList

Vector和ArrayList比较

Vector和ArrayList 都是对List接口的实现类,实现对数组(数据以数组的形式保存)的动态修改。
两者比较建议使用ArrayList,下面对这两种类型的比较。存在即合理,如果以后发现使用Vector优于ArrayList的再进行补充。

  1. 网上很多资料指出Vector是线程安全的。查看源码目前发现提现在两方面

    1)Vector中的方法很多是synchronized的,例如
    - - public synchronized boolean add(E e) // 添加项
    - - public synchronized E remove(int index)//删除项
    2)在进行迭代的时候添加了添加了锁
    - - synchronized (Vector.this)
    如果有需要我们完全可以通过代码控制同步,而不是所有对数组更改都进行同步控制,目前已知synchronized效率低,以后对synchronized的原理进行学习

  2. 增量大小不同(数组到达上限后增加空间的大小)。Vector可以按指定的大小进行扩充,默认是当前数组大小。ArrayList默认是当前数组的一半。
    java笔记--零碎--Vector和ArrayList
    java笔记--零碎--Vector和ArrayList