ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

ArrayList源码

2022-06-11 02:31:09  阅读:164  来源: 互联网

标签:int ArrayList elementData newCapacity minCapacity 源码 size


源码分析

ArrayList

默认容量 DEFAULT_CAPACITY = 10; // 是添加元素之后的默认容量,如果没有添加任何元素,容量为0
存放元素的数组 elementData 添加元素
size 实际元素个数

  // 创建集合 size 0 容量 0 每次扩容会变成原来的1.5倍
  ArrayList arrayList = new ArrayList<>();

  add() // 添加元素
  // add()方法源码
  public boolean add(E e) {
    ensureCapacityInternal(size + 1);    // Increments modCount!!
    elementData[size++] = e;
    return true;
  }

  // ensureCapacityInternal
  private void ensureCapacityInternal(int minCapacity) {
    if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {
      minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
    }
    ensureExplicitCapacity(minCapacity);
  }

  // ensureExplicitCapacity
  private void ensureExplicitCapacity(int minCapacity) {
      modCount++;

      // overflow-conscious code
      if (minCapacity - elementData.length > 0)
          grow(minCapacity);
  }

   // grow 数组扩容方法
      private void grow(int minCapacity) {
        // overflow-conscious code
        int oldCapacity = elementData.length;
        int newCapacity = oldCapacity + (oldCapacity >> 1);
        if (newCapacity - minCapacity < 0)
            newCapacity = minCapacity;
        if (newCapacity - MAX_ARRAY_SIZE > 0)
            newCapacity = hugeCapacity(minCapacity);
        // minCapacity is usually close to size, so this is a win:
        elementData = Arrays.copyOf(elementData, newCapacity);
    }

标签:int,ArrayList,elementData,newCapacity,minCapacity,源码,size
来源: https://www.cnblogs.com/zhiless/p/16365138.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有