Java慎用Vector,因其全局同步导致单线程性能浪费、多线程锁争抢严重;扩容翻倍易造成内存浪费;接口陈旧不兼容现代集合规范;且方法级同步无法保障复合操作原子性。

Java建议慎用Vector,核心原因在于它用“全局同步”换线程安全,代价太高——单线程白耗性能,多线程又锁得太死,还拖着一堆过时设计。
同步开销大,几乎处处拖慢
Vector的add、get、remove等所有公共方法都加了synchronized。这意味着:哪怕你只在单线程里反复读取元素,每次调用都要走锁流程;多个线程哪怕操作不同位置(比如一个读首元素、一个加末尾),也得排队等同一把对象锁。
- 单线程下毫无收益,纯属性能浪费
- 高并发时容易形成锁争抢,吞吐量明显下降
- 现代JVM虽有锁消除优化,但不保证生效,不能依赖
扩容太激进,容易浪费内存
默认初始容量是10,扩容策略是“翻倍”(如10→20→40→80)。相比ArrayList的1.5倍扩容(10→15→22→33…),Vector更容易出现“刚加几个元素,内存就多占一倍”的情况。
- 若指定
capacityIncrement,可控制增长步长,但多数人不用,就默认翻倍 - 对内存敏感或元素数量波动大的场景,这种粗放式扩容不友好
接口陈旧,与现代集合习惯脱节
它保留了Enumeration(如elements())、elementAt()、insertElementAt()等JDK 1.0时代的API,而主流已统一用Iterator和标准List方法。
立即学习“Java免费学习笔记(深入)”;
-
Enumeration不能删除元素,也不支持增强for循环 -
Iterator有remove(),且能配合for-each写法更简洁 - 继承自
AbstractList是后来补的,底层设计并不完全契合Collection框架哲学
真正线程安全?其实并不可靠
每个方法单独同步 ≠ 整体操作原子化。比如判断非空再取首元素:if (!v.isEmpty()) v.get(0);,两个方法之间可能被其他线程修改,仍会出错。
- 业务逻辑常需多步组合,
Vector无法保障这类复合操作的一致性 - 真要线程安全,应选
CopyOnWriteArrayList(适合读多写少)或用Collections.synchronizedList(new ArrayList())(注意:它的迭代器仍需手动同步) - 更复杂的并发场景,优先考虑
java.util.concurrent包里的专用类
基本上就这些。不是说Vector不能用,而是它解决的问题,现代方案能解得更轻、更准、更稳。










