当前位置: 首页 > news >正文

Java 设计模式之迭代器模式

文章目录

  • Java 设计模式之迭代器模式
    • 概述
    • UML
    • 代码实现
    • Java的迭代器

Java 设计模式之迭代器模式

概述

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

UML

在这里插入图片描述

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

代码实现

定义迭代器接口:

public interface Iterator<T> {
    boolean hasNext();

    T next();
}

定义具体迭代器类:

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;
    }
}

定义聚合接口:

public interface Aggregate<T> {
    Iterator<T> createIterator();
}

定义具体聚合类:

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);
    }
}

使用:

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.util.Iterator.java
 
public interface Iterator<E> {   
    boolean hasNext();
    E next();
}
// java.util.ListIterator.java

public interface ListIterator<E> extends Iterator<E> {  
    boolean hasNext(); 
    E next(); 
    boolean hasPrevious(); 
    E previous();
}
http://www.dtcms.com/a/15679.html

相关文章:

  • 头歌实验--面向对象程序设计
  • Kubernetes (k8s) 常用指令速查表
  • 飞书专栏-TEE文档
  • 在 Ubuntu 20.04 为 Clash Verge AppImage 创建桌面图标教程
  • vue2 多页面pdf预览
  • UI自动化测试的优缺点?
  • Python练习11-20
  • 阿里巴巴对deepseek回应
  • 实践记录--电脑故障的问题定位和处理回顾--磁盘故障已解决
  • LVS原理与配置全解析:四层负载均衡核心技术揭秘
  • JAVA AI 框架LangChain4j 入门教程
  • PMP冲刺每日一题(8)
  • javafx HTMLEditor自定义字体
  • Linux Mem -- AArch64 MTE功能Tag寄存器
  • CanMV的刷新比Openmv强
  • Apollo 9.0 参考线生成器 -- ReferenceLineProvider
  • vite创建的react18的@路径提示配置
  • 鸿蒙开发:熟知@BuilderParam装饰器
  • 太速科技-616-基于6U VPX XCVU9P+XCZU7EV的双FMC信号处理板卡
  • Oracle VirtualBox虚拟机软件中安装ubuntu
  • Redission看门狗
  • STM32的HAL库开发---OLED
  • 如何通过5G和边缘计算提升工业远程运维效能?
  • MySQL版本选择与安装
  • java笔试基础
  • 【C++文件读写操作】IO流读文件[程序和文件必须在同一文件夹]
  • DeepSeek R1本地部署教程
  • QT之error: LNK2038: 检测到“RuntimeLibrary”的不匹配项
  • Python函数返回值250214
  • 图数据库Neo4j面试内容整理-属性(Property)