ArrayList源码-Remove方法流程

avatar
作者
筋斗云
阅读量:7

ArrayList的remove方法用于删除ArrayList中指定位置的元素。下面是ArrayList的remove方法的源码和流程:

public E remove(int index) { rangeCheck(index); // 检查索引是否越界 modCount++; // 修改ArrayList结构的操作数加1 E oldValue = elementData(index); // 获取要删除的元素 int numMoved = size - index - 1; if (numMoved > 0) { System.arraycopy(elementData, index + 1, elementData, index, numMoved); // 将后面的元素往前移动一位 } elementData[--size] = null; // 将最后一个元素设为null,方便垃圾回收 return oldValue; // 返回删除的元素 } 

流程如下:

  1. 首先,通过rangeCheck(index)方法检查索引是否越界,如果越界则抛出IndexOutOfBoundsException异常。

  2. 接下来,modCount++ArrayList的修改操作数加1,用于实现fail-fast机制。

  3. 然后,通过elementData(index)方法获取要删除的元素,并将其保存到oldValue变量中。

  4. 接下来,计算出要移动的元素个数,即numMoved = size - index - 1,如果numMoved > 0,则需要将后面的元素往前移动一位。

  5. 使用System.arraycopy方法将后面的元素往前移动一位。

  6. 将最后一个元素设为null,方便垃圾回收。

  7. 最后,返回删除的元素。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!