Vector是线程安全的动态数组,其方法均被synchronized修饰,适用于多线程环境;它基于数组实现,支持自动扩容,默认扩容为原容量两倍,允许null值和重复元素;与ArrayList相比性能较低,因每个操作都加锁,单线程下推荐ArrayList,高并发场景建议使用CopyOnWriteArrayList或Collections.synchronizedList;尽管Vector本身线程安全,但复合操作如检查再添加仍需手动同步;主要用于遗留系统维护,现代开发更推荐java.util.concurrent包中的工具类。

在Java中,Vector 是一个自带线程安全机制的动态数组,它和 ArrayList 类似,但所有关键方法都使用了 synchronized 关键字修饰,因此可以在多线程环境下安全使用。如果你需要一个线程安全的集合而不想手动加锁,Vector 提供了一种简单直接的解决方案。
Vector 的基本特性
Vector 实现了 List 接口,底层基于数组实现,支持自动扩容。与 ArrayList 不同的是,它的增删改查等常用操作都是同步的,即同一时刻只能有一个线程访问这些方法。
- 线程安全:内部方法如 add、get、remove 等都加了 synchronized 锁
- 有序集合:元素按插入顺序排列
- 允许 null 值和重复元素
- 扩容机制:默认扩容为原来的两倍(可指定增量)
创建和初始化 Vector
可以通过无参构造或指定初始容量来创建 Vector 对象。
// 创建空的 Vector,默认初始容量为 10 Vectorvector = new Vector<>(); // 指定初始容量 Vector numbers = new Vector<>(20); // 指定初始容量和扩容增量(每次扩容增加5个元素空间) Vector words = new Vector<>(10, 5);
常用操作方法示例
以下是一些常见的 Vector 使用方式:
立即学习“Java免费学习笔记(深入)”;
vector.add("Hello");
vector.add("World");
vector.add(1, "Java"); // 在索引1处插入
System.out.println(vector.get(0)); // 输出: Hello
System.out.println(vector.size()); // 输出: 3
vector.remove("Java");
vector.contains("World"); // true
// 遍历元素
for (String s : vector) {
System.out.println(s);
}
Vector 与 ArrayList 的性能对比
虽然 Vector 是线程安全的,但这种安全性是以牺牲性能为代价的。每个方法都加锁会导致在高并发场景下出现竞争,影响吞吐量。
- 单线程环境推荐使用 ArrayList + 手动同步控制(如有必要)
- 多线程频繁读取时,可考虑使用 Collections.synchronizedList(new ArrayList()) 或 CopyOnWriteArrayList
- Vector 更适合遗留代码维护或对线程安全要求简单明确的小规模并发场景
注意事项与最佳实践
尽管 Vector 是线程安全的,但在复合操作中仍需额外同步处理,例如检查再添加(check-then-add)这类操作不是原子的。
// 即使是 Vector,下面这段代码也不是线程安全的
if (!vector.contains("new")) {
vector.add("new"); // 中间可能已被其他线程修改
}
此时应手动加锁:
synchronized(vector) {
if (!vector.contains("new")) {
vector.add("new");
}
}
基本上就这些。Vector 提供了开箱即用的线程安全能力,适合简单的多线程场景,但在现代 Java 开发中更推荐使用并发包中的高级工具类来获得更好的性能和灵活性。










