Java的arraylist源码分析 【看懂真的很长知识 多看 以后会多进行源码分析】

arraylist源码分析

   按住Alt 点击ArrayList
  DEFAULT_CAPACITY = 10  //默认容量大小为10
             注意:如果没有向集合中添加任何元素,容量为0  添加一个元素之后容量为10
  elementData  //存放数组的
  size  //实际的元素个数
  add() 添加元素    按住Alt 点击add()方法
  public boolean add(E e) {
          ensureCapacityInternal(size + 1);  // Increments modCount!!
          elementData[size++] = e;
          return true;
      }
      按住Alt 点击 ensureCapacityInternal()方法
   private void ensureCapacityInternal(int minCapacity) {
          if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {
               //minCapacity=1  DEFAULT_CAPACITY=10  Math.max(比较大的)
              minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
          }
                                 //10
          ensureExplicitCapacity(minCapacity);
      }
    private void ensureExplicitCapacity(int minCapacity) {
          modCount++;
  
          // overflow-conscious code
          // 10 -0 >0
          if (minCapacity - elementData.length > 0)
             //  按住Alt 点击 grow()方法
              grow(minCapacity);
      }
      
                               10
      private void grow(int minCapacity) {
          // overflow-conscious code
                     0          0
          int oldCapacity = elementData.length;
                                0            oldCapacity=oldCapacity*2
                   0                           0=0*2    0
          int newCapacity = oldCapacity + (oldCapacity >> 1);
                 0             10 
                 0- 10=-10<0
          if (newCapacity - minCapacity < 0)
                 所以   newCapacity=10         
              newCapacity = minCapacity;
                  不成立
          if (newCapacity - MAX_ARRAY_SIZE > 0)
              newCapacity = hugeCapacity(minCapacity);
          // minCapacity is usually close to size, so this is a win:
           10                                        10
          elementData = Arrays.copyOf(elementData, newCapacity);
          最后得出结论 :添加一个元素之后容量为10 扩容是原来的1.5倍
      }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值