深入探索迭代器模式的原理与应用

server/2024/9/25 14:14:56/

迭代器模式

💻 迭代器模式 (Iterator Pattern) 是一种行为设计模式,它允许你顺序访问一个集合对象中的元素,而无需暴露其底层表示。在不同的数据结构中,如数组、链表或其他集合,它可以统一提供一种方式来逐个遍历这些元素。

主要组成部分和UML类图

  1. Iterator 接口:定义遍历元素所需要的操作,如 hasNext()next().
  2. ConcreteIterator 具体迭代器:实现 Iterator 接口,负责具体遍历操作。
  3. Aggregate 聚合接口:提供创建迭代器的方法 createIterator().
  4. ConcreteAggregate 具体聚合类:实现聚合接口,包含实际元素集合,并返回迭代器实例。

在这里插入图片描述

生动案例理解:图书馆书架

情景:你走进图书馆,看到有许多不同的书架,每个书架有一排书。你想要逐一遍历每本书,但图书馆有不同种类的书架,它们的排列规则不同。使用迭代器模式,你可以通过同一个接口来遍历所有的书架,而无需关心每个书架的具体实现。

代码实现迭代器模式

让我们实现一个书架例子。书架有不同的书,通过迭代器,我们可以按顺序遍历这些书。

Step 1:定义书的类

java">lass Book {private String name;public Book(String name) {this.name = name;}public String getName() {return name;}
}

作用: 定义书的属性和构造函数,通过getName()方法可以获取书名。

Step 2:创建迭代器接口

java">interface BookIterator extends Iterator<Book> {boolean hasNext();Book next();
}

作用: 定义迭代器的接口,提供了hasNext()next()方法,用于遍历书籍。

Step 3: 具体的迭代器实现

java">// 第三步:具体迭代器实现类
class ShelfIterator implements BookIterator {private List<Book> books;private int position = 0;public ShelfIterator(List<Book> books) {this.books = books;}@Overridepublic boolean hasNext() {return position < books.size();}@Overridepublic Book next() {return books.get(position++);}
}

作用: ShelfIterator是迭代器的具体实现类,内部维护了当前遍历的位置并提供具体的遍历实现

Step 4: 定义聚合接口

java">// 第四步:抽象聚合接口
interface BookShelf {BookIterator createIterator();
}

作用: 定义了一个抽象聚合接口,用于创建一个新的迭代器。

Step 5: 实现具体聚合类

java">// 第五步:具体聚合实现类
class LibraryShelf implements BookShelf {private List<Book> books;public LibraryShelf() {this.books = new ArrayList<>();}public void addBook(Book book) {this.books.add(book);}@Overridepublic BookIterator createIterator() {return new ShelfIterator(books);}
}

作用: LibraryShelf是具体的聚合类,管理书籍的集合,并提供创建迭代器的方法。

Step 6: 测试类

java">// 第六步:测试类
public class Main {public static void main(String[] args) {LibraryShelf shelf = new LibraryShelf();shelf.addBook(new Book("Effective Java"));shelf.addBook(new Book("Design Patterns"));shelf.addBook(new Book("Clean Code"));BookIterator iterator = shelf.createIterator();System.out.println("Traversing the book shelf:");while (iterator.hasNext()) {Book book = iterator.next();System.out.println("Book: " + book.getName());}}
}

输出结果

java">Traversing the book shelf:
Book: Effective Java
Book: Design Patterns
Book: Clean Code

通过这个案例,你可以看到迭代器模式如何解耦聚合对象和遍历逻辑,使得可以以统一的方式遍历不同的集合。

JDK源码中的应用

在JDK中,迭代器模式广泛用于Collection框架,特别是在ListSetMap等数据结构中。让我们看看几个常见的示例:

javautilIterator_155">java.util.Iterator

java">public interface Iterator<E> {boolean hasNext();E next();default void remove() {throw new UnsupportedOperationException("remove");}
}

应用: Iterator接口是Java集合框架中的迭代器标准接口。几乎所有的集合类(ArrayList, HashSet, LinkedList)都实现了这个接口,用于提供遍历方法。

javautilArrayList__170">java.util.ArrayList 的迭代器实现

java">public class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, java.io.Serializable {// ArrayList中的内部类实现了Iteratorprivate class Itr implements Iterator<E> {int cursor;       // index of next element to returnint lastRet = -1; // index of last element returned; -1 if no suchpublic boolean hasNext() {return cursor != size();}public E next() {int i = cursor;if (i >= size)throw new NoSuchElementException();cursor = i + 1;return (E) elementData[lastRet = i];}public void remove() {// 删除操作}}public Iterator<E> iterator() {return new Itr();}
}

应用场景: ArrayListiterator() 方法返回的是内部类 Itr 的实例,Itr 实现了 Iterator 接口,通过 hasNext()next() 方法来遍历 ArrayList 中的元素。

迭代器模式总结

优点🟢

  1. 解耦集合与遍历:可以在不暴露集合内部表示的前提下遍历集合。
  2. 统一遍历接口:无论集合的类型或内部实现如何,迭代器提供了一致的遍历接口。
  3. 开闭原则:可以很容易地在不修改集合类的情况下扩展新类型的迭代器。
  4. 单一职责:将遍历逻辑从集合类中分离出来,简化了集合类的职责。

缺点 🔴

  1. 性能开销迭代器模式通常需要额外的类来实现,可能会导致开销增加,尤其是对于大量的小型对象。
  2. 复杂性增加:对简单的数据结构来说,使用迭代器模式可能会使代码更加复杂。

适用场景

  • 遍历复杂数据结构:如树、图、链表等。迭代器可以隐藏这些数据结构的复杂性。
  • 需要统一遍历接口的地方:例如在一个框架或库中,不同的数据结构都需要通过相同的接口遍历。
  • 需要多种遍历方式:如从前到后、从后到前等,迭代器可以轻松扩展不同的遍历方式。

http://www.ppmy.cn/server/121855.html

相关文章

金属材质检测系统源码分享

金属材质检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Vis…

Ubuntu20.04安装ros2

最近需要ubuntu上安装ros&#xff0c;试了很多的博客&#xff0c;会出现网络拒绝等问题。 今天试了一下鱼香ros的一键安装包&#xff0c;非常方便的帮我实现了安装。鱼佬的教程&#xff0c;又有视频又有博客&#xff0c;还有 一键安装包&#xff0c;简直是新手的福音。 强烈看…

【深度学习】(6)--图像数据增强

文章目录 图像数据增强一、作用二、增强方法三、代码体现四、增强体现 总结 图像数据增强 数据增强&#xff08;Data Augmentation&#xff09;&#xff0c;也称为数据增广&#xff0c;是一种在机器学习和深度学习中常用的技术&#xff0c;它通过对现有数据进行各种变换和处理…

FAT32取证分析

前言&#xff1a; 在正常工作中经常会有数据恢复或者取证分析的场景&#xff0c;数据是否能被恢复&#xff0c;主要还是看数据是否被覆盖&#xff0c;正常情况下文件虽然被删除&#xff0c;只是修对应的标志位&#xff0c;文件本身数据并不会被破坏&#xff0c;所以我们就可以…

系统架构笔记-2-计算机系统基础知识

知识要点-2.6计算机语言 UML 对系统架构的定义是系统的组织结构&#xff0c;包括系统分解的组成部分以及它们的关联性、交互机制和指导原则等&#xff0c;提供系统设计的信息。 具体有以下 5 个系统视图&#xff1a; 1. 逻辑视图&#xff1a;也称为设计视图&#xff0c;表示…

Flink 中 Checkpoint 的底层原理和机制

Flink 的 Checkpoint 机制是 Apache Flink 在流式处理中的一个核心特性&#xff0c;保证了分布式数据流处理系统的 容错性。通过定期保存 状态快照&#xff08;checkpoint&#xff09;&#xff0c;即使在发生故障时&#xff0c;Flink 也可以恢复到之前的状态&#xff0c;确保处…

鸿蒙OpenHarmony【轻量系统内核(标准库支持)】子系统开发

CMSIS支持 基本概念 [CMSIS]是Cortex Microcontroller Software Interface Standard&#xff08;Cortex微控制器软件接口标准&#xff09;的缩写&#xff0c;是对于那些基于ARM Cortex处理器的微控制器独立于供应商的硬件抽象层。它包含多个组件层&#xff0c;其中之一是RTOS…

Python轴承故障诊断 (一)短时傅里叶变换STFT

​ 前言 本文基于凯斯西储大学&#xff08;CWRU&#xff09;轴承数据&#xff0c;进行短时傅里叶变换的介绍与参数选择&#xff0c;最后通过Python实现对故障数据的时频图像分类。凯斯西储大学轴承数据的详细介绍可以参考下文&#xff1a; Python-凯斯西储大学&#xff08;CWR…