前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【说站】java中ArrayList集合的扩容机制

【说站】java中ArrayList集合的扩容机制

作者头像
很酷的站长
发布2022-11-23 16:04:55
3860
发布2022-11-23 16:04:55
举报
文章被收录于专栏:站长的编程笔记

java中ArrayList集合的扩容机制

1、扩容要看添加方法,从属性中可以看出有一个DEFAULT_CAPACITY属性值10。

代码语言:javascript
复制
public boolean add(E e) {
    // 验证是否需要扩容操作
    ensureCapacityInternal(size + 1);  // Increments modCount!!
    // 在对应的下标下添加值
    elementData[size++] = e;
    return true;
}

2、刚刚进入ensureCapacityInternal(size+1)size是一个完整的变量。

标记了ArrayList的大小(包含的元素数),而此时没有元素的是ensureCapacityInternal(0+1)。

代码语言:javascript
复制
//1、进入这个方法
private void ensureCapacityInternal(int minCapacity) {
  //2、先调用calculateCapacity(elementData, minCapacity)、这个方法就是检查第一次添加数据、并返回默认的容器大小(就是10)
  // 4、就是执行这个方法ensureExplicitCapacity(10) // 为什么参数是10、就是因为这个方法calculateCapacity(elementData, minCapacity)做了操作。
  ensureExplicitCapacity(calculateCapacity(elementData, minCapacity));
}
//3、数组容量计算
private static int calculateCapacity(Object[] elementData, int minCapacity) {
  // 这个能处理就是第一次添加数据时为真
  if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {
    // 然后这个成立、这个方法是取参数1和参数2、两个数之间的值
    // DEFAULT_CAPACITY : 默认为10
    // minCapacity : 第一次添加数据为1
    // 所以10 和 1 、10大、最后将10返回出去
    return Math.max(DEFAULT_CAPACITY, minCapacity);
  }
  return minCapacity;
}
 
//5、确保显式容量
private void ensureExplicitCapacity(int minCapacity) {
  modCount++;
 
   // 6、做判断、
  // 第一次添加数据时 为 10-0 > 0 :第一次可以成立
  // 第二次添加数据时 为 2-10 > 0 :第二次可以不成立
  if (minCapacity - elementData.length > 0)
    //7、执行下面方法、这个方法的作用才是正真的实施扩容并确定首次扩容ArrayList容器大小的方法
    grow(minCapacity);//扩容
}

以上就是java中ArrayList集合的扩容机制,希望对大家有所帮助。更多Java学习指路:Java基础

本教程操作环境:windows7系统、java10版,DELL G3电脑。

收藏 | 0点赞 | 0打赏

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • java中ArrayList集合的扩容机制
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档