Vector是线程安全的动态数组,通过synchronized方法实现同步,但性能较低,现代开发推荐使用CopyOnWriteArrayList或synchronizedList替代。

Vector 是 Java 中一个古老的集合类,位于 java.util 包中,它和 ArrayList 类似,都是基于动态数组实现的列表结构。但与 ArrayList 不同的是,Vector 的方法大多是同步的,因此它是线程安全的。这使得 Vector 在多线程环境下可以安全地进行增删改查操作,无需额外的同步控制。
Vector 的基本使用方法
Vector 的使用方式与 ArrayList 非常相似,支持添加、删除、访问和遍历元素等常见操作。
示例代码:
Vectorvector = new Vector<>(); // 添加元素 vector.add("A"); vector.add("B"); vector.add("C"); // 获取元素 String first = vector.get(0); // 删除元素 vector.remove("B"); // 遍历 for (String item : vector) { System.out.println(item); }
Vector 为何是线程安全的
Vector 实现线程安全的方式是对大多数公共方法使用 synchronized 关键字修饰。例如 add()、remove()、get()、set() 等方法都加了同步锁,确保同一时刻只有一个线程能执行这些操作。
立即学习“Java免费学习笔记(深入)”;
这意味着:
- 多个线程同时调用 vector.add(element) 时,不会导致数据错乱
- 读取操作(如 get)也被同步,保证读到的数据是最新的
- 在并发场景下,Vector 能避免因竞态条件引发的问题
Vector 的性能问题与替代方案
虽然 Vector 是线程安全的,但由于每个方法都加锁,在高并发或频繁操作的场景下性能较低。过度同步会导致线程阻塞,影响程序效率。
现代 Java 开发中更推荐以下替代方案:
- Collections.synchronizedList(new ArrayList()):可将普通 ArrayList 包装成线程安全的列表
- CopyOnWriteArrayList:适用于读多写少的并发场景,性能更好
示例:
ListsyncList = Collections.synchronizedList(new ArrayList<>()); // 或使用 CopyOnWriteArrayList CopyOnWriteArrayList cowList = new CopyOnWriteArrayList<>();
使用 Vector 时的注意事项
尽管 Vector 是线程安全的,但在某些复合操作中仍需手动同步,比如检查后添加(check-then-act)。
错误示例:
if (!vector.contains("X")) {
vector.add("X"); // 非原子操作,可能出错
}
正确做法:
synchronized(vector) {
if (!vector.contains("X")) {
vector.add("X");
}
}
因为 contains 和 add 是两个独立的同步方法,中间存在时间差,必须用外部同步块保证原子性。
基本上就这些。Vector 能用,但不建议在新项目中广泛使用。了解它的机制有助于维护老系统,但现代并发编程更推荐使用 java.util.concurrent 包下的工具类。










