AbstractList类如何在不实现Iterator<E>接口的情况下提供Iterator<E>接口的实现?
创始人
2024-07-22 14:00:39
0

AbstractList类提供了一个受保护的方法modCount,这个方法将在每次对列表进行结构修改时自增,用于实现检测并发修改的机制。AbstractList类还提供了两个抽象方法 listIterator()和 size(),这两个方法的实现由具体的子类来完成。

为了实现Iterator接口,AbstractList类提供了一个内部类Itr来遍历列表中的元素。这个内部类继承了Iterator接口,并实现了hasNext()、next()和remove()等方法。Itr内部还有一个重要的变量 expectedModCount,用于记录Itr对象创建时的modCount值,以便在遍历期间检测并发修改。

以下是简化版的AbstractList和Itr代码示例:

public abstract class AbstractList extends AbstractCollection implements List {
  protected int modCount;

  public Iterator iterator() {
    return new Itr();
  }

  public abstract ListIterator listIterator(int index);

  public abstract int size();

  private class Itr implements Iterator {
    int cursor;

    int expectedModCount = modCount;

    public boolean hasNext() {
      return cursor != size();
    }

    public E next() {
      checkForComodification();
      int i = cursor;
      cursor = i + 1;
      return AbstractList.this.get(i);
    }

    public void remove() {
      // 省略实现
    }

    final void checkForComodification() {
      if (modCount != expectedModCount)
        throw new ConcurrentModificationException();
    }
  }
}

public class ArrayList extends AbstractList implements List, RandomAccess, Cloneable, Serializable {
  private transient Object[] elementData;

  public int size() {
    return size;
  }

  public ListIterator listIterator(int index) {
    // 省略实现
  }
}

相关内容

热门资讯

Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
Android - 无法确定任... 这个错误通常发生在Android项目中,表示编译Debug版本的Java代码时出现了依赖关系问题。下...
Android - NDK 预... 在Android NDK的构建过程中,LOCAL_SRC_FILES只能包含一个项目。如果需要在ND...
Alertmanager在pr... 首先,在Prometheus配置文件中,确保Alertmanager URL已正确配置。例如:ale...
Akka生成Actor问题 在Akka框架中,可以使用ActorSystem对象生成Actor。但是,当我们在Actor类中尝试...
Agora-RTC-React... 出现这个错误原因是因为在 React 组件中使用,import AgoraRTC from “ago...
Aksnginxdomainb... 在AKS集群中,可以使用Nginx代理服务器实现根据域名进行路由。以下是具体步骤:部署Nginx i...
Alertmanager中的基... Alertmanager中可以使用repeat_interval选项指定在一个告警重复发送前必须等待...
AddSingleton在.N... 在C#中创建Singleton对象通常是通过私有构造函数和静态属性来实现,例如:public cla...