设计模式——迭代器模式

迭代器模式(Iterator Pattern)是一种行为型设计模式,它提供了一种方法来顺序访问聚合对象中的元素,而又不需要暴露其底层表示。迭代器允许程序员遍历不同的数据结构(如列表、集合或树),而无需了解这些结构的具体实现细节。

原理

  • 迭代器接口(Iterator): 定义了访问和遍历元素所需的接口,通常包含hasNext()、next()等方法。
  • 具体迭代器(Concrete Iterator): 实现迭代器接口,负责跟踪当前遍历位置,并根据需要访问和返回聚合对象的下一个元素。
  • 聚合接口(Aggregate): 提供一个创建迭代器的方法,用于遍历内部元素。
  • 具体聚合类(Concrete Aggregate): 具体实现聚合接口,存储数据并创建与自身数据结构相匹配的迭代器实例。

Java代码示例

java 复制代码
// 聚合接口
public interface Container {
    Iterator<Item> getIterator();
}

// 具体聚合类 - 数组列表容器
public class ArrayListContainer implements Container {
    private Item[] items;

    public ArrayListContainer(Item[] items) {
        this.items = items;
    }

    @Override
    public Iterator<Item> getIterator() {
        return new ArrayListIterator();
    }

    private class ArrayListIterator implements Iterator<Item> {
        private int position = 0;

        @Override
        public boolean hasNext() {
            return position < items.length && items[position] != null;
        }

        @Override
        public Item next() {
            if (!hasNext()) {
                throw new NoSuchElementException();
            }
            return items[position++];
        }

        // remove() 方法在此简化示例中未实现
    }
}

// 抽象迭代器接口
public interface Iterator<Item> {
    boolean hasNext();
    Item next();
}

// 使用示例
public class Client {
    public static void main(String[] args) {
        Item[] items = {new Item("A"), new Item("B"), new Item("C")};
        Container container = new ArrayListContainer(items);
        
        Iterator<Item> iterator = container.getIterator();

        while (iterator.hasNext()) {
            System.out.println(iterator.next());
        }
    }
}

// 简化的元素类
public class Item {
    private String name;

    public Item(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return "Item: " + name;
    }
}

想象你有一个装满了书的书架,但书架有各种各样的形状和大小。迭代器就像是一个能够帮你找到书架上每本书的图书管理员,不论书架结构如何复杂。每次当你说"下一本"时,图书管理员都能准确地拿出一本书给你,而你并不需要知道书架内部是怎么存放书籍的。

应用场景

  • Java Collections Framework:如ArrayList、LinkedList、HashSet等都实现了Iterable接口,可以通- 过for-each循环或其他方式使用迭代器进行遍历。
  • 数据库查询结果集:数据库驱动程序为查询结果提供迭代器,通过迭代器逐行读取结果数据。

适用性

  • 需要遍历集合对象的所有元素,而不想暴露集合的内部表示时。
  • 支持对集合对象的多种遍历方式,例如正序、逆序或者按照某种特定规则遍历时。
  • 在同一聚合对象上有多个遍历算法的情况下,可以针对每个算法提供一个专门的迭代器类。
相关推荐
GM_8283 分钟前
【最新最完整】SpringAI-1.0.0开发MCP Server,搭建MCP Client 实战笔记(进阶+详细+完整代码)
java·后端·ai编程·springai·mcp
都叫我大帅哥4 分钟前
Java DelayQueue:时间管理大师的终极武器
java
秋千码途12 分钟前
小架构step系列27:Hibernate提供的validator
java·spring·架构·hibernate
都叫我大帅哥13 分钟前
TOGAF迁移规划阶段全解密:从菜鸟到达人的通关秘籍
java
探索java14 分钟前
深入理解 Spring 中的 XmlBeanFactory 原理及实践
java·spring·xmlbeanfactory
hqxstudying2 小时前
Java异常处理
java·开发语言·安全·异常
我命由我123455 小时前
Kotlin 数据容器 - List(List 概述、创建 List、List 核心特性、List 元素访问、List 遍历)
java·开发语言·jvm·windows·java-ee·kotlin·list
武子康7 小时前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
YuTaoShao10 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
源码_V_saaskw10 小时前
JAVA图文短视频交友+自营商城系统源码支持小程序+Android+IOS+H5
java·微信小程序·小程序·uni-app·音视频·交友