Java 设计模式之迭代器模式

文章目录

Java 设计模式之迭代器模式

概述

  • 迭代器模式(Iterator),提供一种方法顺序访问一个聚合对象中的各个元素,而又不暴露该对象的内部表示。

UML

  • Iterator:迭代器接口,定义遍历方法。
  • ConcreteIterator:具体迭代器类,实现迭代器接口,负责遍历聚合对象中的元素。
  • Aggregate:聚合接口,定义创建迭代器方法。
  • ConcreteAggregate:具体聚合类,实现聚合接口,负责存储数据和创建迭代器对象。

代码实现

定义迭代器接口:

java 复制代码
public interface Iterator<T> {
    boolean hasNext();

    T next();
}

定义具体迭代器类:

java 复制代码
public class BookIterator implements Iterator<String> {
    private ArrayList<String> bookList;
    private int position = 0;

    public BookIterator(ArrayList<String> bookList) {
        this.bookList = bookList;
    }

    @Override
    public boolean hasNext() {
        return position < bookList.size();
    }


    @Override
    public String next() {
        if (hasNext()) {
            return bookList.get(position++);
        }
        return null;
    }
}

定义聚合接口:

java 复制代码
public interface Aggregate<T> {
    Iterator<T> createIterator();
}

定义具体聚合类:

java 复制代码
public class BookCollection implements Aggregate<String> {
    private ArrayList<String> bookList = new ArrayList<>();

    public void addBook(final String book) {
        bookList.add(book);
    }

    @Override
    public Iterator<String> createIterator() {
        return new BookIterator(bookList);
    }
}

使用:

java 复制代码
public class Client {
    public static void main(String[] args) {
        BookCollection bookCollection = new BookCollection();
        bookCollection.addBook("西游记");
        bookCollection.addBook("水浒传");
        bookCollection.addBook("红楼梦");
        bookCollection.addBook("三国演义");
        Iterator<String> iterator = bookCollection.createIterator();
        while (iterator.hasNext()) {
            System.out.println(iterator.next());
        }
    }
}

输出:

复制代码
西游记
水浒传
红楼梦
三国演义

Java的迭代器

Java 提供了迭代器的相关接口:

java 复制代码
// java.util.Iterator.java
 
public interface Iterator<E> {   
    boolean hasNext();
    E next();
}
java 复制代码
// java.util.ListIterator.java

public interface ListIterator<E> extends Iterator<E> {  
    boolean hasNext(); 
    E next(); 
    boolean hasPrevious(); 
    E previous();
}
相关推荐
二月夜8 小时前
剖析Java正则表达式回溯问题
java·正则表达式
xuhaoyu_cpp_java8 小时前
项目学习(三)分页查询
java·经验分享·笔记·学习
程序员二叉8 小时前
【Java】集合面试全套精讲|HashMap/ArrayList高频考点完整版
java·面试·哈希算法
cfm_29149 小时前
JVM GC垃圾回收初步了解
java·开发语言·jvm
心之伊始9 小时前
LangChain4j RAG 实战:Java 后端如何把本地文档接入 Embedding 检索链路
java·架构·源码分析·csdn
许彰午10 小时前
17_synchronized关键字深度解析
java·开发语言
Xzh042311 小时前
AI Agent 学习路线(Java 后端方向)
java·人工智能·学习
艾利克斯冰12 小时前
Java 设计模式-行为型模式(更新中)
java·开发语言·设计模式
倒霉蛋小马12 小时前
Java新特性:record关键字
java·开发语言
折哥的程序人生 · 物流技术专研12 小时前
《Java 100 天进阶之路》第95篇:消息队列基础(RocketMQ/Kafka)(2026版)
java·面试·kafka·rocketmq·java-rocketmq·求职招聘