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?
内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)