Vector是线程安全的动态数组,通过synchronized方法实现同步,但性能较低,现代开发推荐使用CopyOnWriteArrayList或synchronizedList替代。
Vector 是 Java 中一个古老的集合类,位于 java.util 包中,它和 ArrayList 类似,都是基于动态数组实现的列表结构。但与 ArrayList 不同的是,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 实现线程安全的方式是对大多数公共方法使用 synchronized 关键字修饰。例如 add()、remove()、get()、set() 等方法都加了同步锁,确保同一时刻只有一个线程能执行这些操作。
这意味着:
虽然 Vector 是线程安全的,但由于每个方法都加锁,在高并发或频繁操作的场景下性能较低。过度同步会导致线程阻塞,影响程序效率。
现代 Java 开发中更推荐以下替代方案:
示例:
ListsyncList = Collections.synchronizedList(new ArrayList<>()); // 或使用 CopyOnWriteArrayList CopyOnWriteArrayList cowList = new CopyOnWriteArrayList<>();
尽管 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 包下的工具类。