搜索
首页Javajava教程java ArrayList集合的扩容机制

java ArrayList集合的扩容机制

Apr 26, 2023 pm 03:40 PM
javaarraylist

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

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

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

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

//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集合的扩容机制的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:亿速云。如有侵权,请联系admin@php.cn删除

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境