Java慎用Vector,因其全局同步导致单线程性能浪费、多线程锁争抢严重;扩容翻倍易造成内存浪费;接口陈旧不兼容现代集合规范;且方法级同步无法保障复合操作原子性。
Java建议慎用Vector,核心原因在于它用“全局同步”换线程安全,代价太高——单线程白耗性能,多线程又锁得太死,还拖着一堆过时设计。
Vector的add、get、remove等所有公共方法都加了synchronized。这意味着:哪怕你只在单线程里反复读取元素,每次调用都要走锁流程;多个线程哪怕操作不同位置(比如一个读首元素、一个加末尾),也得排队等同一把对象锁。
默认初始容量是10,扩容策略是“翻倍”(如10→20→40→80)。相比ArrayList的1.5倍扩容(10→15→22→33…),Vector更容易出现“刚加几个元素,内存就多占一倍”的情况。
capacityIncrement,可控制增长步长,但多数人不用,就默认翻倍它保留了Enumeration(如elements())、elementAt()、insertElementAt()等JDK 1.0时代的API,而主流已统一用Iterator和标准List方法。
Enu
meration不能删除元素,也不支持增强for循环Iterator有remove(),且能配合for-each写法更简洁AbstractList是后来补的,底层设计并不完全契合Collection框架哲学每个方法单独同步 ≠ 整体操作原子化。比如判断非空再取首元素:if (!v.isEmpty()) v.get(0);,两个方法之间可能被其他线程修改,仍会出错。
Vector无法保障这类复合操作的一致性CopyOnWriteArrayList(适合读多写少)或用Collections.synchronizedList(new ArrayList())(注意:它的迭代器仍需手动同步)java.util.concurrent包里的专用类基本上就这些。不是说Vector不能用,而是它解决的问题,现代方案能解得更轻、更准、更稳。