Vector底层源码解析

Java源码系列:下方连接
http://t.csdn.cn/Nwzed



前言

Vector集合总结:Vector实现了List接口,Java1.0版本推出,底层也是一个Object数组elementData,与Arraylist不同的时,Vector是线程安全的,每个方法几乎都有synchronilzed关键字,所以在多线程的情况下,应该使用Vector集合。

Vector的数组长度默认是10,满后按照2倍进行扩容,如果制定大小则直接按2倍扩容,除了线程安全和默认10容量与2倍扩容,几乎和Arraylist没有什么区别。


提示:以下是本篇文章正文内容,下面案例可供参考

集合体系继承图
在这里插入图片描述
Vector相对于ArrayList来说,Vector是线程安全的,它的每个方法几乎都加了synchronized关键字,Vector也是基于数组来存储元素的。
在这里插入图片描述
在这里插入图片描述

​​​​​​​​

一、Vectro底层源码逐步解析

还是和上一章的一样,就是换了一个集合。

老规矩,先来到无参构造,里面直接调用this关键字带赋值一个10进去,我们都知道this表示当前对象,也就是在无参构造中,调用了有参构造传了一个10进去。
在这里插入图片描述
可以看到在有参构造又调用了当前对象的另一个有参构造,构造一个具有指定初始容量且容量增量等于零的空向量,我们接着往下走
在这里插入图片描述
往下走,我们就走到了有参构造应该调用的方法,可见使用Vactro即使我们不传入参数也会自动调用到有参构造,上面传了一个 10 和 0 ,过来先拿 initialCapacity和0进行比较,如果小于0就抛出异常,因为我们的数组长度不能为负数。如果没有抛出异常将 10 赋值给 elementData 数组缓冲区(默认是0),执行完这一步我们就有了一个容量为 10 Vectro集合,继续往下走最后一步this.capacityIncrement = capacityIncrement; 这表示数组的容量增量,调用有参构造是传的 10,0 所以容量增量是 0
在这里插入图片描述
在这里插入图片描述

有了 长度为10的集合 然后往下走 add 方法,还是会先自动装箱,
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

从自动装箱出来,真正进入 add( ) ,可以看见Vector的add方法有 synchronized关键字修饰,是线程安全的。有线程拿到同步锁后。会先将监视器 modCount++,然后再去调用 ensureCapacityHelper( ) 计算容量看看是否需要扩容,

在这里插入图片描述
调用到 ensureCapacityHelper 方法,拿传过来的 minCapacity和默认的 10 进行比较,如果大于 0 就需要扩容,现在程序肯定是不会去扩容的,所以会一路返回到 add 方法。
在这里插入图片描述
返回到 add 方法,会把 e 的值 放入 elementData[ ] 的 elementCount下标处,elementCount下标是 0 ,等 e 的数据放入后进行 elementCount++,就变成了 1,下次添加元素会让 elementCount + 1去计算容量,不管计算结果如何,最后一路再返回到 add 方法,就会将元素放入 elementCount 的下标位置,由于上次进行了自加一,就会放在下标为 1 的位置,再让 elementCount ++,以便下次的计算容量。
在这里插入图片描述
由于默认数组为 10 ,现在一直没有扩容,我们让程序走到 for循环到11,进行扩容。
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

走到扩容的方法,和ArrayList的大同小异,先拿到 lod的值,再用 old加上一个old也就是二倍扩容,但是这里为什么要使用三元表达式,而不去直接加一个 old上去,是因为 capacityIncrement 是用来标记 容量增量 的一个属性,通过三元表达式计算容量增量,如果为 true 大于 0,就使用自定义的容量增量,如果为 false就进行二倍扩容。然后将 old X 2 = 20 赋值给 newCapacity,判断 newCapacity - minCapacity < 0吗?20 - 11肯定大于 0 ,然后直接执行 Arrays.copyOf( ) 进行扩容。

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值