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

Vector 是 Java 中一个古老的集合类,位于 java.util 包中,它和 ArrayList 类似,都是基于动态数组实现的列表结构。但与 ArrayList 不同的是,Vector 的方法大多是同步的,因此它是线程安全的。这使得 Vector 在多线程环境下可以安全地进行增删改查操作,无需额外的同步控制。
Vector 的基本使用方法
Vector 的使用方式与 ArrayList 非常相似,支持添加、删除、访问和遍历元素等常见操作。
示例代码:
Vector<String> vector = 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:适用于读多写少的并发场景,性能更好
示例:
List<String> syncList = Collections.synchronizedList(new ArrayList<>()); // 或使用 CopyOnWriteArrayList CopyOnWriteArrayList<String> cowList = new CopyOnWriteArrayList<>();
使用 Vector 时的注意事项
尽管 Vector 是线程安全的,但在某些复合操作中仍需手动同步,比如检查后添加(check-then-act)。
错误示例:
if (!vector.contains("X")) {
vector.add("X"); // 非原子操作,可能出错
}
正确做法:
synchronized(vector) {
if (!vector.contains("X")) {
vector.add("X");
}
}
</font>
因为 contains 和 add 是两个独立的同步方法,中间存在时间差,必须用外部同步块保证原子性。
基本上就这些。Vector 能用,但不建议在新项目中广泛使用。了解它的机制有助于维护老系统,但现代并发编程更推荐使用 java.util.concurrent 包下的工具类。










