新闻资讯

质量为本、客户为根、勇于拼搏、务实创新

< 返回新闻资讯列表

ArrayList源码-Remove方法流程,arraylist源码分析

发布时间:2023-09-19 07:45:28

ArrayList源码-Remove方法流程

ArrayList的remove方法用于删除ArrayList中指定位置的元素。下面是ArrayList的remove方法的源码和流程:
```java
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. 最后,返回删除的元素。