Vector是线程安全的动态数组,通过synchronized方法保证同步,适合低并发场景,但性能较低,扩容可自定义,遍历时仍需注意并发修改问题。

在Java中,Vector 是一个自带线程安全机制的动态数组实现类,它继承自 AbstractList 并实现了 List 接口。由于其内部方法大多使用 synchronized 关键字修饰,因此多个线程访问时不会导致数据不一致问题,适合在多线程环境下使用。
Vector的基本用法
Vector 的使用方式与 ArrayList 非常相似,但默认就是线程安全的。你可以像操作普通列表一样添加、删除和访问元素。
示例代码:
Vectorvector = new Vector<>(); vector.add("Java"); vector.add("Python"); vector.add("C++"); System.out.println(vector.get(0)); // 输出:Java vector.remove(1); System.out.println(vector); // 输出:[Java, C++]
上述代码展示了 Vector 的基本增删改查操作,语法与 ArrayList 几乎一致。
立即学习“Java免费学习笔记(深入)”;
Vector的线程安全性原理
Vector 的线程安全来源于其关键方法都被 synchronized 修饰。例如:
add(E e)remove(Object o)get(int index)set(int index, E element)
这意味着每次调用这些方法时,都会自动获取对象锁,防止多个线程同时修改集合内容。虽然这保证了安全性,但也带来了性能开销,尤其在高并发场景下可能成为瓶颈。
容量增长机制
Vector 内部也采用数组存储元素,当容量不足时会自动扩容。与 ArrayList 不同的是,Vector 提供了构造函数允许指定容量增量。
常用构造函数:
-
Vector():初始容量为10,扩容时容量翻倍 -
Vector(int initialCapacity):指定初始容量 -
Vector(int initialCapacity, int capacityIncrement):可设置每次扩容增加的大小
例如:
// 初始容量20,每次扩容增加5 Vectorvec = new Vector<>(20, 5);
这个特性让开发者可以更精细地控制内存分配行为,减少频繁扩容带来的性能损耗。
遍历Vector的推荐方式
遍历 Vector 有多种方式,但在多线程环境下需注意迭代器的安全性。
常用遍历方法:
- 增强for循环(简洁但需注意并发修改)
- Iterator(支持 remove 操作)
- forEach + Lambda(JDK 8+)
- 传统for循环(通过索引访问)
示例:
vector.forEach(System.out::println);
for (String item : vector) {
System.out.println(item);
}
尽管 Vector 本身是线程安全的,但如果在遍历时其他线程修改了集合,仍可能抛出 ConcurrentModificationException,建议在遍历期间避免并发修改,或使用额外同步控制。
Vector vs ArrayList vs CopyOnWriteArrayList
选择合适的线程安全集合很重要:
- Vector:方法级同步,简单直接,适合低并发场景
- ArrayList:非线程安全,性能高,需配合 Collections.synchronizedList 使用
- CopyOnWriteArrayList:写操作复制整个数组,读操作无锁,适合读多写少的并发场景
如果项目不需要严格的同步开销,推荐使用 Collections.synchronizedList(new ArrayList()) 或 CopyOnWriteArrayList 替代 Vector。
基本上就这些。Vector 虽然古老,但在一些遗留系统或多线程工具类中仍有应用价值。理解它的同步机制和性能特点,有助于做出合理的技术选择。










