Java中Vector和ArrayList的区别
ArrayList是最常用的List实现类,内部是通过数组实现的,它允许对元素进行快速随机访问。数组的缺点是每个元素之间不能有间隔,当数组大小不满足时需要增加存储能力,就要讲已经有数组的数据复制到新的存储空间中。当从ArrayList的中间位置插入或者删除元素时,需要对数组进行复制、移动、代价比较高。因此,它适合随机查找和遍历,不适合插入和删除。
Vector与ArrayList一样,也是通过数组实现的,不同的是它支持线程的同步,即某一时刻只有一个线程能够写Vector,避免多线程同时写而引起的不一致性,但实现同步需要很高的花费,因此,访问它比访问ArrayList慢。
ArrayList
public?boolean?add(E?e)?{ensureCapacity(size?+?1);//?增加元素,判断是否能够容纳。不能的话就要新建数组
elementData[size++]?=?e;
return?true;
}
public?void?ensureCapacity(int?minCapacity)?{modCount++;?
int?oldCapacity?=?elementData.length;
if?(minCapacity?>?oldCapacity)?{
Object?oldData[]?=?elementData;?
int?newCapacity?=?(oldCapacity?*?3)/2?+?1;?//?增加新的数组的大小
if?(newCapacity??oldCapacity)?{
Object[]?oldData?=?elementData;
int?newCapacity?=?(capacityIncrement?>?0)
(oldCapacity?+?capacityIncrement)?:?(oldCapacity?*?2);if?(newCapacity?
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!