ArrayList与vector的对比

参考博客

ArrayList与Vector区别
arrayList和vector的区别


ArrayList和Vector在java集合框架图中的位置

java集合框架图

说明:对于以上的框架图有如下几点说明

  1. 所有集合类都位于java.util包下。Java的集合类主要由两个接口派生而出:CollectionMapCollectionMap是Java集合框架的根接口,这两个接口又包含了一些子接口或实现类。

  2. 集合接口:6个接口(短虚线表示),表示不同集合类型,是集合框架的基础。

  3. 抽象类:5个抽象类(长虚线表示),对集合接口的部分实现。可扩展为自定义集合类。

  4. 实现类:8个实现类(实线表示),对接口的具体实现。

  5. Collection 接口是一组允许重复的对象。

  6. Set 接口继承 Collection,集合元素不重复。

  7. List接口继承 Collection,允许重复,维护元素插入顺序。

  8. Map接口是键-值对象,与Collection接口没有什么关系。

  9. SetListMap可以看做集合的三大类:

  • List集合是有序集合,集合中的元素可以重复,访问集合中的元素可以根据元素的索引来访问。
  • Set集合是无序集合,集合中的元素不可以重复,访问集合中的元素只能根据元素本身来访问(也是集合里元素不允许重复的原因)。
  • Map集合中保存Key-value对形式的元素,访问时只能根据每项元素的key来访问其value

ArrayList与Vector的主要区别

VectorArrayList一样,也是通过数组实现的,不同的是它支持线程的同步,即某一时刻只有一个线程能够写Vector,避免多线程同时写而引起的不一致性,但实现同步需要很高的花费,因此,访问它比访问ArrayList慢。


ArrayList与Vector的其他重要区别

如果集合中的元素的数目大于目前集合数组的长度时,Vector增长率为目前数组长度的100%,而Arraylist增长率为目前数组长度的50%.如过在集合中使用数据量比较大的数据,用Vector有一定的优势。


ArrayList与Vector用法

  1. 因为Vector是线程同步的,而ArrayList不是同步的,所以在需要线程同步的地方必须使用Vector,除非增加了其他线程安全措施;而在不需要线程同步的地方,使用ArrayList的执行效率更高。
  2. 因为Vector空间增长的速度大于ArrayList,所以在数据量变化大的情况下使用Vector的效率更高。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值