每天一道面试题-ArrayList和Vector的区别

本文对比了ArrayList和Vector两种集合类的特性。ArrayList提供更高的性能但不具备线程安全性,而Vector则相反,它确保了线程安全但牺牲了一部分性能。通过对源码的分析,我们发现Vector通过synchronized关键字实现同步,这导致了其在多线程环境下操作的开销。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先,推荐大家使用ArrayList,了解这个差别,更多是为了应对面试。

两者的最大差异就是线程安全

ArrayList:线程不安全,但性能高

Vector:线程安全,但性能较低

我们如何得到一个类是线程安全或不安全的结论的?

从源码的角度来说,你大可以打开ArrayList和Vector的源码一对比,即可发现

ArrayList的部分源码:

public boolean add(E e) {ensureCapacityInternal(size + 1); // Increments modCount!!elementData[size++] = e;return true;}

Vector的部分源码:

public synchronized boolean add(E e) {modCount++;ensureCapacityHelper(elementCount + 1);elementData[elementCount++] = e;return true;}

大家看出差异了吗?

每天一道面试题-ArrayList和Vector的区别

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值