集合框架之ArrayList底层长度扩容实现

ArrayList:底层为数组,元素有序,存在索引
在jdk1.8之后,它的默认构造函数的长度为0;(之前默认10)
private static final int DEFAULT_CAPACITY = 10;
private static final Object[] EMPTY_ELEMENTDATA = {};
private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
三个成员变量控制它的长度初始化值
在这里插入图片描述
1、它的默认构造函数长度为null;
2、看它的add()方法:
在这里插入图片描述
1、调用第一个方法,给它赋初始值,大小在最小容量和DEFAULT_CAPACITY的值中取最大值
2、比较它的长度和数据长度大小,执行grow()方法
在这里插入图片描述
这就是它的扩容机制,他的最大扩容长度为
private static final int MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;

如果还不够,就执行hugeCapacity(minCapacity);方法

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值