Vector是线程安全的动态数组,通过synchronized修饰方法实现同步,确保多线程下数据一致,但性能较低,现代开发推荐使用CopyOnWriteArrayList或Collections.synchronizedList替代。

Java 中的 Vector 是一个线程安全的动态数组,它和 ArrayList 类似,但关键区别在于它的方法大多使用了 synchronized 关键字修饰,从而保证在多线程环境下访问时不会出现数据不一致的问题。
Vector 的线程安全机制
Vector 实现线程安全的核心方式是:对大多数修改和访问集合的方法进行了同步处理。例如 add、remove、get、set 等操作都加了 synchronized 修饰符,这意味着同一时刻只能有一个线程进入这些方法。
以添加元素为例:
public synchronized boolean add(E e) {modCount++;
ensureCapacityHelper(elementCount + 1);
elementData[elementCount++] = e;
return true;
}
这个 synchronized 修饰符作用于实例方法,锁的是当前 Vector 对象本身(this),因此多个线程同时调用同一个 Vector 实例的 add 方法时,会串行执行,避免并发修改导致的问题。
立即学习“Java免费学习笔记(深入)”;
Vector 的常见线程安全操作示例
下面是一个简单的多线程环境下使用 Vector 的例子:
import java.util.Vector;public class VectorExample {
public static void main(String[] args) {
Vector
Runnable task = () -> {
for (int i = 0; i vector.add(Thread.currentThread().getName() + "-" + i);
}
};
new Thread(task).start();
new Thread(task).start();
try { Thread.sleep(2000); } catch (InterruptedException e) { }
System.out.println("总元素数:" + vector.size());
}
}
尽管两个线程并发添加元素,Vector 内部的同步机制能确保每个 add 操作原子执行,最终结果不会出现数组越界或数据覆盖等并发问题。
Vector 的性能与替代方案
虽然 Vector 是线程安全的,但由于每个方法都加锁,频繁调用时会造成较大的性能开销。比如遍历操作 get(int index) 也被 synchronized 修饰,即使读操作理论上可以并发进行,Vector 仍强制串行化。
现代 Java 开发中更推荐以下替代方式:
- 使用 Collections.synchronizedList(new ArrayList()) 包装 ArrayList,可细粒度控制同步范围
- 使用 CopyOnWriteArrayList,适用于读多写少场景,读操作无需加锁
- 在需要高性能并发集合时优先考虑 java.util.concurrent 包下的工具类
基本上就这些。Vector 确实是线程安全的,靠的是方法级别的 synchronized 同步,适合简单场景,但在高并发下建议使用更高效的并发集合替代。










