Vector的底层扩容机制

一、Vector的有参扩容机制

首先了解下ArrayList的主要区别:

  • 我们知道ArrayLIst查询效率高:ArrayLIst是连续存放元素的,找到第一个元素的首地址,再加上每个元素的占据的字节大小就能定位到对应的元素,但是线程不安全.
  • 而Vector很多方法都有同步关键字synchronized,从而保证所有的对外接口都会以 Vector对象为锁,即在vector内部,所有的方法都不会被多线程访问。

下面通过debug分析Vector的底层扩容机制:
1.1 首先进入默认的无参构造函数中,在这里插入图片描述1.2再调用有参构造函数,初始化容量为10;
在这里插入图片描述
1.3在调用带有2个参数的构造函数,初始化elementData为10,capacityIncrement为0在这里插入图片描述
1.3扩容的其他步骤和ArrayList的步骤大都相同,只是扩容中grow()方法方式有点不同,当第11个元素添加时,进入grow()方法
在这里插入图片描述
扩容为原来的2倍
在这里插入图片描述

二、Vector的有参扩 容机制

        List<Object> vector = new Vector<>(15);
        for (int i = 1; i <=15 ; i++) {
            vector.add(i);
        }
        vector.add(16);
        vector.add(17);

2.1进入带1个参数的构造中
在这里插入图片描述
2.1进入2个参数的构造中,初始化elementData15,capacityIncrement为0,下面的步骤和无参的步骤完全相同
在这里插入图片描述
总结:
- Vector的扩容如果为无参构造方式,则第一次为10,之后的每一次扩容都为2倍.
- 如果是有参方式,直接扩容为原来的两倍

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

2年工作经验的小胡歌

你的打赏是对博主最大的支持和鼓

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值