ArrayList非线程安全但性能高,Vector线程安全但性能低;2. Vector扩容2倍,ArrayList扩容1.5倍;3. Vector为早期类,ArrayList更现代推荐使用。

ArrayList 和 Vector 都是 Java 中用于存储动态数组的集合类,它们都继承自 AbstractList,但在实际使用中存在几个关键区别。
1. 线程安全性
Vector 是线程安全的,它的大多数方法都被 synchronized 修饰,意味着在多线程环境下访问时不需要额外的同步控制。
ArrayList 不是线程安全的,如果多个线程同时修改 ArrayList 实例而没有外部同步,可能会导致数据不一致或抛出异常。
建议:在单线程场景下优先使用 ArrayList,性能更好;若需线程安全,可考虑使用 Collections.synchronizedList(new ArrayList()) 或 CopyOnWriteArrayList。
2. 性能表现
由于 Vector 的方法是同步的,每次调用 add、get、remove 等操作都会加锁,因此在单线程环境中比 ArrayList 慢。
立即学习“Java免费学习笔记(深入)”;
ArrayList 没有同步开销,访问和修改速度更快。
3. 扩容机制
两者在容量不足时都会自动扩容:
- Vector 默认扩容为原来大小的 2 倍
- ArrayList 扩容为原来的 1.5 倍
这个差异会影响内存使用效率和扩容频率。Vector 可能浪费更多空间,但减少扩容次数;ArrayList 更节省内存。
4. 继承与历史背景
Vector 属于早期 Java 集合框架(JDK 1.0),而 ArrayList 是在 JDK 1.2 引入的,作为更现代的替代方案。
尽管 Vector 还在使用,但它已被视为“遗留类”,官方推荐在非特殊需求下使用 ArrayList 或其他并发集合。
基本上就这些。日常开发中,除非明确需要线程安全且不关心性能,否则更推荐使用 ArrayList。