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

设计模式十七:迭代器模式(Iterator Pattern)

迭代器模式(Iterator Pattern)是一种行为型设计模式,它提供了一种访问聚合对象(例如列表、集合、数组等)中各个元素的方法,而无需暴露其内部表示。迭代器模式将遍历元素和访问元素的责任分离开来,使得代码更加灵活、可扩展和易于维护。
迭代器模式的核心思想是抽象出一个迭代器接口,该接口定义了访问和遍历元素的方法,然后不同的聚合对象实现这个接口以提供自己的迭代器。这样,客户端代码就可以通过迭代器遍历聚合对象中的元素,而无需关心聚合对象的具体实现细节。

迭代器的使用场景

迭代器模式在许多情况下都可以发挥作用,特别是在需要遍历和访问集合或聚合对象的场景中。以下是一些常见的使用场景:

  1. 遍历集合类:
    迭代器模式最典型的用途就是遍历集合类(如列表、集合、数组等)中的元素,而无需暴露集合的内部结构。这可以让你在遍历过程中保持代码的清晰性和灵活性。
  2. 封装集合的底层实现:
    迭代器模式可以将集合的底层实现与遍历操作分离开,从而让你可以更换或升级集合的底层实现,而不影响遍历代码。
  3. 支持不同的遍历方式:
    如果你希望支持不同的遍历方式,例如前向、后向、跳跃等,你可以通过实现不同的迭代器来达到目的。
  4. 隐藏复杂的遍历逻辑:
    如果集合中的元素存储方式比较复杂,或者遍历逻辑比较繁琐,你可以通过迭代器模式将这些复杂性隐藏起来,让客户端代码更加简洁。
  5. 支持多线程安全的遍历:
    在多线程环境中,使用迭代器模式可以实现安全的遍历操作,避免多个线程同时访问集合造成的问题。
  6. 遍历数据库查询结果
    当从数据库中获取查询结果时,你可以使用迭代器模式遍历查询结果集,从而逐个处理每条记录。
  7. 遍历文件系统目录:
    在处理文件系统目录结构时,你可以使用迭代器模式遍历目录中的文件和子目录。
  8. 访问组合模式中的对象:
    在组合模式中,你可以使用迭代器模式遍历组合对象中的叶子节点和容器节点。

迭代器模式的主要角色

  1. 迭代器接口(Iterator):定义访问和遍历元素的方法,抽象出了迭代器的行为。
  2. 具体迭代器(ConcreteIterator):实现迭代器接口,负责实际遍历聚合对象的元素。
  3. 聚合接口(Aggregate):定义获取迭代器的方法,抽象出聚合对象的行为
  4. 具体聚合(ConcreteAggregate):实现聚合接口,负责创建具体的迭代器。

迭代器模式的java实现实例

public class Book {private String title;public Book(String title) {this.title = title;}public String getTitle() {return title;}
}
package cn.iterator.service;import java.util.Iterator;public class BookCollection implements Iterable<Book> {private Book[] books;private int size;public BookCollection(int capacity) {books = new Book[capacity];size = 0;}public void addBook(Book book) {if (size < books.length) {books[size++] = book;}}@Overridepublic Iterator<Book> iterator() {return new BookIterator();}// 自定义迭代器private class BookIterator implements Iterator<Book> {private int currentIndex = 0;@Overridepublic boolean hasNext() {return currentIndex < size;}@Overridepublic Book next() {return books[currentIndex++];}}
}
public class Iterator {public static void main(String[] args) {BookCollection bookCollection = new BookCollection(3);bookCollection.addBook(new Book("Java Programming"));bookCollection.addBook(new Book("Design Patterns"));bookCollection.addBook(new Book("Data Structures"));// 使用迭代器遍历书籍集合for (Book book : bookCollection) {System.out.println("Book Title: " + book.getTitle());}}}

当执行到
for(Book book : bookCollection)会有两步操作
在这里插入图片描述
1.判断是否有下一个数据
在这里插入图片描述
2.返回下一个数据
在这里插入图片描述

迭代器模式的优缺点

迭代器模式在许多情况下能够提供更好的代码组织和可维护性,但也需要权衡其引入的复杂性和性能问题。在设计时需要根据具体情况来判断是否使用迭代器模式以及如何使用
优点:

  1. 分离遍历逻辑
    迭代器模式将遍历和访问元素的逻辑与聚合对象的具体实现分离开来,使客户端代码更加简洁,减少了与元素遍历相关的重复代码。
  2. 支持多种遍历方式:
    通过实现不同的迭代器,可以轻松支持不同的遍历方式,如正向遍历、逆向遍历、跳跃遍历等,而不需要改变客户端代码。
  3. 隐藏聚合对象的内部结构:
    迭代器模式可以将聚合对象的内部结构隐藏起来,提高了聚合对象的封装性和安全性,同时避免了直接暴露实现细节。
  4. 可替换性和灵活性:
    由于客户端代码只依赖于迭代器接口,而不依赖于具体的聚合对象,因此可以轻松地替换不同的聚合对象和迭代器实现,以适应不同的需求和变化。
  5. 适用于各种聚合对象:
    迭代器模式适用于各种聚合对象,无论是数组、链表、集合还是自定义的聚合类型,都可以通过实现迭代器来提供统一的遍历方式。

缺点:

  1. 增加了类的数量:
    引入迭代器模式会增加额外的类和接口,从而增加了代码的复杂性,特别是对于简单的聚合对象而言,可能会显得过于繁琐。
  2. 可能引起性能问题:
    在某些情况下,使用迭代器模式可能会引起性能问题,特别是在遍历大量数据时。迭代器模式需要维护迭代器对象,可能会造成一定的开销。
  3. 不适合每种情况:
    尽管迭代器模式适用于大多数需要遍历聚合对象的情况,但并不是所有场景都适合使用。对于一些简单的遍历操作,直接使用循环可能更加简单直接。

相关文章:

设计模式十七:迭代器模式(Iterator Pattern)

迭代器模式&#xff08;Iterator Pattern&#xff09;是一种行为型设计模式&#xff0c;它提供了一种访问聚合对象&#xff08;例如列表、集合、数组等&#xff09;中各个元素的方法&#xff0c;而无需暴露其内部表示。迭代器模式将遍历元素和访问元素的责任分离开来&#xff0…...

Python制作爱心并打包成手机端可执行文件

前言 本文是想要将python代码打包成在手机上能执行的文件 尝试了几个库&#xff0c; 有这也那样的限制&#xff0c;最终还是选了BeeWare 环境&#xff1a;python3.7.x 开始 找到打包有相关工具os-android-apk-builder&#xff0c;buildozer&#xff0c;cx_Freeze&#xff…...

使用docker-compose.yml快速搭建开发、部署环境(nginx、tomcat、mysql、jar包、各种程序)以及多容器通信和统一配置

目录 docker-compose语法&#xff08;更多说明可查看下面代码&#xff09;imagehostnamecontainer_namevolumesnetworks yml文件的使用启动停止 开发环境&#xff08;这里以python为例&#xff09;部署环境nginxmysqltomcatjar包打包后的可执行程序 常见问题与解决方案多个容器…...

管理类联考——逻辑——真题篇——按知识分类——汇总篇——二、论证逻辑——支持加强——第三节——分类3——类比题干支持

文章目录 第三节 支持加强-分类3-类比题干支持真题(2017-28)-支持加强-正面支持-表达“确实如此”真题(2017-36)-支持加强-正面支持-表达“确实如此”真题(2017-39)-支持加强-正面支持-方法有效或方法可行,但多半不选择方法无恶果真题(2017-50)-支持加强真题(2018-2…...

搜索旋转排序数组

整数数组 nums 按升序排列&#xff0c;数组中的值 互不相同 。 在传递给函数之前&#xff0c;nums 在预先未知的某个下标 k&#xff08;0 < k < nums.length&#xff09;上进行了 旋转&#xff0c;使数组变为 [nums[k], nums[k1], …, nums[n-1], nums[0], nums[1], …, …...

Steam搬砖项目:最长久稳定的副业!

项目应该大家都有听说话&#xff0c;但是细节问题&#xff0c;如何操作可能有些不是很清楚&#xff0c;今天在这里简单分享一下。 这个Steam搬砖项目主要赚钱汇率差和价值差&#xff0c;是一个细分领取的小项目。 不用引流&#xff0c;时间也是比较自由的&#xff0c;你可以兼…...

最小化安装移动云大云操作系统--BCLinux-R8-U8-Server-x86_64-230802版

CentOS 结束技术支持&#xff0c;转为RHEL的前置stream版本后&#xff0c;国内开源Linux服务器OS生态转向了开源龙蜥和开源欧拉两大开源社区&#xff0c;对应衍生出了一系列商用Linux服务器系统。BC-Linux V8.8是中国移动基于龙蜥社区Anolis OS 8.8版本深度定制的企业级X86服务…...

神经网络基础-神经网络补充概念-05-导数

概念 导数是微积分中的一个概念&#xff0c;用于描述函数在某一点的变化率。在数学中&#xff0c;函数的导数表示函数值随着自变量的微小变化而产生的变化量&#xff0c;即斜率或变化率。 假设有一个函数 f(x)&#xff0c;其中 x 是自变量&#xff0c;y f(x) 是因变量。函数…...

kubernetes — 安装Ingress

1、 Ingress 1、安装-Nginx-Ingress kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/controller-v1.8.1/deploy/static/provider/cloud/deploy.yaml 2、设为默认的Ingress [rootk8s01 ~]# vim default_ingress.yaml apiVersion: networking.…...

SSR使用HTTPS

1.安装 npm i browser-sync 2. 再angular.json里配置 "serve-ssr": {"builder": "nguniversal/builders:ssr-dev-server","options": {"ssl": true,"sslCert": "./node_modules/browser-sync/certs/server…...

Spring Boot中使用validator如何实现接口入参自动检验

文章目录 一、背景二、使用三、举例 一、背景 在项目开发过程中&#xff0c;经常会对一些字段进行校验&#xff0c;比如字段的非空校验、字段的长度校验等&#xff0c;如果在每个需要的地方写一堆if else 会让你的代码变的冗余笨重且相对不好维护&#xff0c;如何更加规范和优…...

thinkphp 5 实现UNION ALL 3个联表查询,并且带上搜索条件,名称,时间,手机号

在ThinkPHP 5中实现带有搜索条件、名称、时间和手机号的3个联表查询&#xff08;UNION ALL&#xff09;&#xff0c;您可以按照以下步骤进行操作&#xff1a; 确保已经配置好数据库连接信息和相关的模型。 使用union()方法来构建3个联表查询&#xff0c;同时在每个查询中添加所…...

React 之 Router - 路由详解

一、Router的基本使用 1. 安装react-router react-router会包含一些react-native的内容&#xff0c;web开发并不需要 npm install react-router-dom 2. 设置使用模式 BrowserRouter或HashRouter Router中包含了对路径改变的监听&#xff0c;并且会将相应的路径传递给子组件Bro…...

框架分析(1)-IT人必须会

框架分析&#xff08;1&#xff09;-IT人必须会 专栏介绍当今主流框架前端框架后端框架移动应用框架数据库框架测试框架 Angular关键特点和功能&#xff1a;组件化架构双向数据绑定依赖注入路由功能强大的模板语法测试友好 优缺点分析优点缺点 总结 专栏介绍 link 主要对目前市…...

前端面试的游览器部分(7)每天10个小知识点

目录 系列文章目录前端面试的游览器部分&#xff08;1&#xff09;每天10个小知识点前端面试的游览器部分&#xff08;2&#xff09;每天10个小知识点前端面试的游览器部分&#xff08;3&#xff09;每天10个小知识点前端面试的游览器部分&#xff08;4&#xff09;每天10个小知…...

认识Junit

1. 前言 2. Junit注解 2.1. 常用的注解 2.1.1. Test 表示当前方法是一个测试方法(不需要main来执行) Test void Test01() throws InterruptedException {System.out.println("测试用例1");WebDriver webDriver new ChromeDriver();webDriver.get("https:/…...

Unity C# 引用池 ReferencePool

Unity C# 引用池 ReferencePool 1.目的 对于多次创建的数据使用new 关键字是十分消耗性能的&#xff0c;使用完成后由GC去自动释放&#xff0c;当一个类型的数据频繁创建可以使用引用池进行管理。 2.实现 项目目录 IReference 接口 要放入引用池的数据只需要继承这个接口…...

opencv 进阶10-人脸识别原理说明及示例-cv2.CascadeClassifier.detectMultiScale()

人脸识别是指程序对输入的人脸图像进行判断&#xff0c;并识别出其对应的人的过程。人脸识别程 序像我们人类一样&#xff0c;“看到”一张人脸后就能够分辨出这个人是家人、朋友还是明星。 当然&#xff0c;要实现人脸识别&#xff0c;首先要判断当前图像内是否出现了人脸&…...

〔013〕Stable Diffusion 之 图片自动评分和不健康内容过滤器 篇

✨ 目录 🎈 下载咖啡美学评价插件🎈 咖啡美学评价使用🎈 不健康内容过滤器插件🎈 下载咖啡美学评价插件 想让系统帮你的图片作品打分评价,可以下载咖啡美学自动评价插件插件地址:https://github.com/p1atdev/stable-diffusion-webui-cafe-aesthetic也可以通过扩展列表…...

6.RocketMQ之消费索引文件ConsumeQueue

功能&#xff1a;作为CommitLog文件的索引文件。 本文着重分析为consumequeue/topic/queueId目录下的索引文件。 1.ConsumeQueueStore public class ConsumeQueueStore {protected final ConcurrentMap<String>, ConcurrentMap<Integer>, ConsumeQueueInterface…...

Appium-移动端自动测试框架,如何入门?

Appium是一个开源跨平台移动应用自动化测试框架。 既然只是想学习下Appium如何入门&#xff0c;那么我们就直奔主题。文章结构如下&#xff1a; 1、为什么要使用Appium&#xff1f; 2、如何搭建Appium工具环境?(超详细&#xff09; 3、通过demo演示Appium的使用 4、Appium如何…...

复数混频器、零中频架构和高级算法开发

文章里讲解了关于射频IQ调制器、零中频架构相关的原理及技术&#xff0c;全都是干货&#xff01;其实好多同行对软件无线电的原理、IQ调制、镜像抑制都是一知半解&#xff0c;知其然不知其所以然。好好研读这篇文章&#xff0c;相信会让你有种恍然大悟的感觉。 RF工程常被视为…...

Web 拦截器-interceptor

拦截器是一种动态拦截方法调用的机制&#xff0c;类似于过滤器&#xff0c;是Spring框架提出的&#xff0c;用来动态拦截控制器方法的执行。 其作用是拦截请求&#xff0c;在指定方法调用前后&#xff0c;根据业务执行预设代码。 实现步骤 1.定义拦截器&#xff0c;实现Handl…...

Java进阶(4)——结合类加载JVM的过程理解创建对象的几种方式:new,反射Class,克隆clone(拷贝),序列化反序列化

目录 引出类什么时候被加载JVM中创建对象几种方式1.new 看到new : new Book()2.反射 Class.forName(“包名.类名”)如何获取Class对象【反射的基础】案例&#xff1a;连接数据库方法 3.克隆&#xff08;拷贝&#xff09;clone浅拷贝深拷贝案例 序列化和反序列化对象流-把对象存…...

扩散模型实战(四):从零构建扩散模型

推荐阅读列表&#xff1a; 扩散模型实战&#xff08;一&#xff09;&#xff1a;基本原理介绍 扩散模型实战&#xff08;二&#xff09;&#xff1a;扩散模型的发展 扩散模型实战&#xff08;三&#xff09;&#xff1a;扩散模型的应用 本文以MNIST数据集为例&#xff0c;从…...

YOLOv5、YOLOv8改进:S2注意力机制

目录 1.简介 2.YOLOv5改进 2.1增加以下S2-MLPv2.yaml文件 2.2common.py配置 2.3yolo.py配置 1.简介 S2-MLPv2注意力机制 最近&#xff0c;出现了基于 MLP 的视觉主干。与 CNN 和视觉Transformer相比&#xff0c;基于 MLP 的视觉架构具有较少的归纳偏差&#xff0c;在图像识…...

LeetCode 542. 01 Matrix【多源BFS】中等

本文属于「征服LeetCode」系列文章之一&#xff0c;这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁&#xff0c;本系列将至少持续到刷完所有无锁题之日为止&#xff1b;由于LeetCode还在不断地创建新题&#xff0c;本系列的终止日期可能是永远。在这一系列刷题文章…...

使用open cv进行角度测量

使用open cv进行角度测量 用了一点初中数学的知识&#xff0c;准确度&#xff0c;跟鼠标点的准不准有关系&#xff0c;话不多说直接上代码 import cv2 import mathpath "test.jpg" img cv2.imread(path) pointsList []def mousePoint(event, x, y, flags, param…...

java 线程池实现多线程处理list数据

newFixedThreadPool线程池实现多线程 List<PackageAgreementEntity> entityList new CopyOnWriteArrayList<>();//多线程 10个线程//int threadNum 10;int listSize 300;List<List<PackageAgreementDto>> splitData Lists.partition(packageAgre…...

Centos安装Docker

Centos安装 Docker 从 2017 年 3 月开始 docker 在原来的基础上分为两个分支版本: Docker CE 和 Docker EE。 Docker CE 即社区免费版&#xff0c;Docker EE 即企业版&#xff0c;强调安全&#xff0c;但需付费使用。 本文介绍 Docker CE 的安装使用。 移除旧的版本&#x…...

.net网站方案/seo是什么服务器

在OAF页面的查找后台的数据源相对于在Form中显得更加麻烦&#xff0c;同时也无法像Form中那样能够较为准确的定位&#xff0c;但是也能够查找出大部分的内容。 本文介绍如何使用OAF提供的诊断功能来快速查找OAF页面对应的数据库对象&#xff1a; 关于本页功能(About this Page)…...

网站建设有利点/东莞seo技术

6242: LHC的二进制升级版 时间限制:1秒内存限制:128MBSpecial Judge提交:6正确:3题目描述 在发现了3的二进制特殊性质后&#xff0c;LHC认为形如1、3、7、15......2n−1之类的数具有共通的性质。但是他太懒了&#xff0c;请你帮他验证结论吧。现在&#xff0c;LHC要求你在1s内判…...

乐云seo商城网站建设/男生最喜欢的浏览器

声明&#xff1a; 以下内容为阅读由周志明编著的《深入理解Java虚拟机JVM高级特性与最佳实战》&#xff08;第二版&#xff09;自行总结记录&#xff0c;算不上完全解读了大神的意思&#xff0c;但也没有瞎写。如果写的不清楚的地方&#xff0c;还望能够自行阅读原著。这里写记…...

网站百度突然不收录/广告设计

HTML代码&#xff1a; <ul><li>jQuery判断当前元素是第几个元素示例</li><li>jQuery获取第N个元素示例</li><li>jQuery选择器示例</li> </ul> 判断当前元素是第几个元素 如果我们点击任何一个li标签&#xff0c;想知道当前点击…...

大气企业网站源码/下载百度语音导航地图

继续更新设计模式系列。写这个模式的主要原因是近期看到了动态代理的代码。 先来回想一下前5个模式&#xff1a; - Android开发中无处不在的设计模式——单例模式 - Android开发中无处不在的设计模式——Builder模式 - Android开发中无处不在的设计模式——观察者模式 - A…...

山东省城乡建设厅官网/济南seo全网营销

联系人为最常用的功能了&#xff0c;就相当手机上的通讯录&#xff0c;本文介绍 联系人的 新建&#xff0c;删除&#xff0c;编辑&#xff0c;自定议栏位等。以下为联系人添加联系字段&#xff0c;QQ字段功能。星号必须要输入。自定义显示格式&#xff0c;可以拖动哟。查看&…...