栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

2021-10-18

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

2021-10-18

Vector的底层扩容机制
    • 一、Vector的有参扩容机制
    • 二、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 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倍.
- 如果是有参方式,直接扩容为原来的两倍

转载请注明:文章转载自 www.mshxw.com
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号