猿问

ArrayList源码中实现Iterator接口中的next方法时,为什么使用定义一个Object[] elementData。

ArrayList源码中实现Iterator接口中的next方法时,为什么定义Object[] elementData = ArrayList.this.elementData,然后从定义的elementData数组上取值。 return (E) elementData[lastRet = i]。而不是直接使用 ArrayList.this.elementData[lastRet = i]?

源码:

public E next() {
    checkForComodification();
    int i = cursor;
    if (i >= size)
        throw new NoSuchElementException();
    Object[] elementData = ArrayList.this.elementData;
    if (i >= elementData.length)
        throw new ConcurrentModificationException();
    cursor = i + 1;
    return (E) elementData[lastRet = i];
}
萧十郎
浏览 625回答 3
3回答

慕尼黑的夜晚无繁华

如果这么写: if (i >= ArrayList.this.elementData.length) throw new ConcurrentModificationException(); cursor = i + 1; return (E) ArrayList.this.elementData[lastRet = i]; 那么程序会多一次不必要的寻址。

慕标5832272

依我看来这应该主要是为了使得代码更加的简洁

小怪兽爱吃肉

为了少敲几下,以及代码的可读性。
随时随地看视频慕课网APP

相关分类

Java
我要回答