java设计模式迭代器模式_迭代器设计模式示例

java设计模式迭代器模式

本文是我们名为“ Java设计模式 ”的学院课程的一部分。

在本课程中,您将深入研究大量的设计模式,并了解如何在Java中实现和利用它们。 您将了解模式如此重要的原因,并了解何时以及如何应用模式中的每一个。 在这里查看 !

目录

1.简介 2.什么是迭代器设计模式 3.实施迭代器设计模式 4.内部和外部迭代器
4.1。 内部迭代器 4.2。 外部迭代器
5.何时使用迭代器设计模式 6. JDK中的迭代器模式 7.下载源代码

1.简介

聚合对象(例如列表)应该为您提供一种在不暴露其内部结构的情况下访问其元素的方法。 此外,您可能想以不同的方式遍历列表,具体取决于要完成的工作。 但是,即使您可以预料到需要的遍历,您也可能不想用用于不同遍历的操作来充实List接口。 您可能还需要在同一列表上进行多个遍历。

通过Iterator模式,您可以完成所有这些操作。 此模式的关键思想是将访问和遍历的责任从列表对象中移出,并将其放入迭代器对象中。 Iterator类定义用于访问列表元素的接口。 迭代器对象负责跟踪当前元素。 也就是说,它知道已经遍历了哪些元素。

2.什么是迭代器设计模式

迭代器设计模式的目的是提供一种在不暴露其基础表示的情况下顺序访问聚合对象的元素的方法。

迭代器模式允许客户端对象以顺序方式访问容器的内容,而无需了解其内容的内部表示形式。 上面使用的术语“容器”可以简单地定义为数据或对象的集合。 容器内的对象又可以是集合,使其成为集合的集合。

迭代器模式使客户端对象可以遍历对象(或容器)的此集合,而无需容器透露内部如何存储数据。 为此,Iterator模式建议应将Container对象设计为以Iterator对象的形式提供一个公共接口,以供不同的客户端对象访问其内容。 Iterator对象包含公共方法,以允许客户端对象在容器内的对象列表中导航。

图1-类图

图1-类图

迭代器

  • 定义用于访问和遍历元素的接口。

ConcreteIterator

  • 实现Iterator接口。
  • 跟踪聚合中的当前位置。

骨料

  • 定义用于创建Iterator对象的接口。

混凝土骨料

  • 实现Iterator创建接口以返回适当的ConcreteIterator的实例。

3.实施迭代器设计模式

让我们使用Shape类实现Iterator Design Pattern。 我们将使用迭代器存储和迭代Shape对象。

package com.javacodegeeks.patterns.iteratorpattern;public class Shape {private int id;private String name;public Shape(int id, String name){this.id = id;this.name = name;}public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}@Overridepublic String toString(){return "ID: "+id+" Shape: "+name;}}

简单的Shape类具有一个idname作为其属性。

package com.javacodegeeks.patterns.iteratorpattern;public class ShapeStorage {private Shape []shapes = new Shape[5];private int index;public void addShape(String name){int i = index++;shapes[i] = new Shape(i,name);}public Shape[] getShapes(){return shapes;}
}

上面的类用于存储Shape对象。 该类包含一个Shape类型的数组,为简单起见,我们已将该数组初始化为最多5个addShape方法用于向该数组添加Shape对象,并将索引加1。 getShapes方法返回Shape类型的数组。

package com.javacodegeeks.patterns.iteratorpattern;import java.util.Iterator;public class ShapeIterator implements Iterator<Shape>{private Shape [] shapes;int pos;public ShapeIterator(Shape []shapes){this.shapes = shapes;}@Overridepublic boolean hasNext() {if(pos >= shapes.length || shapes[pos] == null)return false;return true;}@Overridepublic Shape next() {return shapes[pos++];}@Overridepublic void remove() {if(pos <=0 )throw new IllegalStateException("Illegal position");if(shapes[pos-1] !=null){for (int i= pos-1; i<(shapes.length-1);i++){shapes[i] = shapes[i+1];}shapes[shapes.length-1] = null;}}
}

上面的类是Shape类的Iterator 。 这个类实现了Iterator接口和定义的所有方法Iterator接口。

如果还有一个项目, hasNext方法将返回一个boolean 。 next方法从集合中返回下一个项目,而remove方法从集合中删除当前项目。

package com.javacodegeeks.patterns.iteratorpattern;public class TestIteratorPattern {public static void main(String[] args) {ShapeStorage storage = new ShapeStorage();storage.addShape("Polygon");storage.addShape("Hexagon");storage.addShape("Circle");storage.addShape("Rectangle");storage.addShape("Square");ShapeIterator iterator = new ShapeIterator(storage.getShapes());while(iterator.hasNext()){System.out.println(iterator.next());}System.out.println("Apply removing while iterating...");iterator = new ShapeIterator(storage.getShapes());while(iterator.hasNext()){System.out.println(iterator.next());iterator.remove();}}}

上面的代码将导致以下输出:

ID: 0 Shape: Polygon
ID: 1 Shape: Hexagon
ID: 2 Shape: Circle
ID: 3 Shape: Rectangle
ID: 4 Shape: Square
Apply removing while iterating...
ID: 0 Shape: Polygon
ID: 2 Shape: Circle
ID: 4 Shape: Square

在上面的类中,我们创建了一个ShapeStorage对象并将Shape对象存储在其中。 接下来,我们创建一个ShapeIterator对象,并ShapeIterator分配形状。 我们重复了两次,首先不调用remove方法,然后再使用remove方法。

输出显示了remove方法的影响。 第一次迭代时,迭代器将打印所有形状,但是当调用remove方法时,它将首先打印当前形状并移至下一个形状。 然后,我们在其上调用remove方法,该方法将删除当前形状,然后迭代器指向下一个可用的形状对象。

因此,“在迭代时应用删除...”之后的输出仅显示0、2和4个形状对象。

4.内部和外部迭代器

迭代器可以设计为内部迭代器或外部迭代器。

4.1内部迭代器

  • 集合本身提供允许客户端访问集合中不同对象的方法。 例如, java.util.ResultSet类包含数据,还提供诸如next的方法来浏览项目列表。
  • 任何给定时间集合上只能有一个迭代器。
  • 集合必须维护或保存迭代状态。

4.2外部迭代器

  • 迭代功能与集合分离,并保留在另一个称为迭代器的对象中。 通常,集合本身会根据客户端的输入向客户端返回适当的迭代器对象。 例如, java.util.Vector类的迭代器以Enumeration类型的单独对象的形式定义。 响应elements()方法调用,此对象返回到客户端对象。
  • 在任何给定时间,给定集合上可以有多个迭代器。
  • 存储迭代状态所涉及的开销与集合无关。 它位于独占的Iterator对象中。

5.何时使用迭代器设计模式

使用迭代器模式:

  • 在不暴露其内部表示的情况下访问聚合对象的内容。
  • 支持聚合对象的多次遍历。
  • 为遍历不同的聚合结构提供统一的接口(即,支持多态迭代)。

6. JDK中的迭代器模式

  • java.util.Iterator
  • java.util.Enumeration

7.下载源代码

这是关于迭代器设计模式的课程。 您可以在此处下载源代码: IteratorPattern-Project

翻译自: https://www.javacodegeeks.com/2015/09/iterator-design-pattern.html

java设计模式迭代器模式

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/337080.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

平衡二叉树 C语言代码实现

点击蓝字关注我们因公众号更改推送规则&#xff0c;请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络&#xff0c;侵删1.什么是平衡二叉树平衡二叉树&#xff0c;我们也称【二叉平衡搜索树/AVL】,树中任何节点的两个子树的高度最大差别为1&#xff0c;巴拉巴拉。。…

api报错 javaee maven_maven test 换javaee6 无法加载spring的配置文件 ?报错-问答-阿里云开发者社区-阿里云...

maven 构建的springmvc项目,执行mvn test 时 如果是org.apache.openejbjavaee-api5.0-3那么执行test可以通过如果将version改为6.0-3 则报错, Failed to load ApplicationContextTest:RunWith(SpringJUnit4ClassRunner.class)ContextConfiguration(locations "classpath*…

研发项目wbs分解简单案例_做项目WBS(工作分解结构)

显示视图栏:右键左边灰色&#xff0c;选“视图栏”。预先设置&#xff1a;文件---》选项&#xff0c;可以设置日期等格式信息&#xff0c;比如可以把日期格式改成2009年1月28日 12:33&#xff0c; 把工期显示单位改成小时数&#xff0c;这样我们可以做更细的任务分解。新建日历…

hystrix熔断 简介_Hystrix简介–总结

hystrix熔断 简介这是其他两篇文章的后续文章– 动机 &#xff0c;说明为什么在分布式系统中需要类似Hystrix的内容以及Hystrix的基本介绍 。 这将是我的Hystrix旅程的总结&#xff0c;其中包含各种属性的详细信息&#xff0c;这些属性可以进行调整以更改Hystrix的行为&#x…

UDP/TCP 包的大小限制知多少

点击蓝字关注我们因公众号更改推送规则&#xff0c;请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络&#xff0c;侵删一、MTU 简述 - 分包后数据包最大长度1、定义Maximum Transmission Unit&#xff08;最大可传输单元&#xff09; 的缩写&#xff0c;它的单位是…

autocad2014 菜单栏 闪退_AutoCAD2014闪退的原因与处理办法 1打开就闪退怎样办

软件安装&#xff1a;装机软件必备包关于电脑装机必须的软件&#xff0c;比如windows office系列办公软件、网页浏览器、杀毒软件、安全防护软件、刻录软件、压缩软件、下载工具、多媒体播放软件、多媒体编辑软件、输入法、图片查看和处理软件、聊天沟通工具、系统工具与驱动补…

java ee的小程序_扩展Java EE应用程序的基础

java ee的小程序老实说&#xff0c;“可扩展性”是一个详尽的主题&#xff0c;并且通常没有被很好地理解。 通常&#xff0c;它被认为与高可用性相同。 我已经看到新手程序员和“经验丰富”的建筑师都建议将“ 群集 ”作为可伸缩性和HA的解决方案。 它实际上没有任何问题&#…

28 张图,一次性说清楚 TCP,速度

点击蓝字关注我们因公众号更改推送规则&#xff0c;请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络&#xff0c;侵删做IT相关的工作&#xff0c;肯定都离不开网络&#xff0c;网络中最重要的协议是TCP。无论是实际工作还是笔试面试&#xff0c;你看哪里能少得了T…

晨风机器人怎么买奴隶_潮牌复刻和正品该怎么抉择???带你了解了解

今天带你们聊一聊潮牌复刻和正品&#xff0c;简单介绍一下我自己&#xff0c;在复刻圈子五年&#xff0c;我的原则从始至终就是质量放在第一位&#xff0c;之所以能走这么久也是这个原因。回归正题&#xff0c;接着往下看。无论是正品还是复刻&#xff0c;其实还要根据自己的能…

php cdi_本机CDI限定词:@Any和@Default

php cdi让我们看一下CDI中的开箱即用的限定词 CDI规范声明了三个限定符– Any&#xff0c; Default&#xff0c; New Any &#xff1a;将其视为无所不在的限定词。 它在那里&#xff0c;即使不是;-) Default &#xff1a;顾名思义&#xff0c;当没有其他限定符时&#xff0…

C语言字符串函数strcat | strcpy | strlen | strcmp的用法及原型

点击蓝字关注我们因公众号更改推送规则&#xff0c;请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络&#xff0c;侵删strcat(str1,str2) 意为将字符串str2连接到字符串str1之后strcat用法如下#include <stdio.h> #include <string.h>int main () {cha…

crntos7启动php命令_CentOS7设置php-fpm开机自启动

php-fpm安装成功后并不会开机启动&#xff0c;如果是运行正常的程序在系统重启后出现502报错(502 Bad Gateway)&#xff0c;通常就是php-fpm没启动起来。0 先确定几个文件的位置&#xff0c;记录下来备用a php-fpmwhich php-fpm/usr/sbin/php-fpmb conf#几个可能的位置#/etc/ph…

java jpa 异步编程_异步处理时的JPA

java jpa 异步编程几年前&#xff0c;在Java世界中&#xff0c;几乎显而易见的是&#xff0c;每个“企业”类项目都需要JPA与数据库进行通信。 JPA是Joel Spolsky描述的“ 泄漏抽象 ”的完美示例。 刚开始时很棒而又容易&#xff0c;但是最后很难调整和限制。 对于许多参与数据…

C语言字符数组与字符串的使用详解

点击蓝字关注我们因公众号更改推送规则&#xff0c;请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络&#xff0c;侵删正文1、字符数组的定义与初始化字符数组的初始化&#xff0c;最容易理解的方式就是逐个字符赋给数组中各元素。char str[10]{ I, ,a,m, ,‘h,a,p…

SRC挖洞网集合

阿里SRC https://security.alibaba.com/ 蚂蚁集团SRC https://security.alipay.com/ 阿里本地生活SRC https://asrc.alibaba.com/#/ 京东安全应急响应中心 https://security.jd.com/#/ 腾讯SRC https://security.tencent.com/ 美团安全应急响应中心 https://security.meit…

不能将紧实的字段 绑定到_代码整洁之道【笔记】

一、整洁代码A.混乱的代价1.有些团队在项目初期进展迅速&#xff0c;但有那么一两年的时间却慢去蜗行。对代码的每次修改都影响到其他两三处代码2.花时间保持代码整洁不但有关效率&#xff0c;还有关生存3.程序员遵从不了解混乱风险经理的意愿&#xff0c;也是不专业的做法4.Bj…

存根类 测试代码 java_测试双打:模拟,假人和存根

存根类 测试代码 java大多数班级都有合作者。 在进行单元测试时&#xff0c;您通常希望避免使用那些协作者的实际实现方式来避免测试的脆弱性和绑定/耦合&#xff0c;而应使用测试双打&#xff1a;模拟&#xff0c;存根和双打。 本文引用了有关该主题的两篇现有文章&#xff1…

5 个牛逼的算法设计,你知道几个?

点击蓝字关注我们因公众号更改推送规则&#xff0c;请点“在看”并加“星标”第一时间获取精彩技术分享来源于网络&#xff0c;侵删1、分治法概念&#xff1a;将一个难以直接解决的大问题&#xff0c;分割成一些规模较小的相同问题&#xff0c;以便各个击破&#xff0c;分而治之…

python2.7.10安装教程_Linux系统(CentOS)下python2.7.10安装

本文记录了Linux系统(CentOS)安装Python&#xff0c;供大家参考&#xff0c;具体内容如下Python(Linux) 下载地址操作系统&#xff1a;Centos6.41、下载下载的版本&#xff1a;Python-2.7.10.tgz2、安装一般情况下&#xff0c;Linux都会预装 Python了&#xff0c;但版本较低。(…

javafx窗体程序_JavaFX实际应用程序:AISO HRC-Matic

javafx窗体程序“ Real-World JavaFX Apps”系列中的第三个应用程序是一种重型数据输入应用程序&#xff0c;由称为HRC-Matic的关系数据库支持。 它由AISO在日内瓦开发。 AISO是一家专门开发基于JavaFX的业务应用程序的公司。 他们还在研究我在本系列的第一个博客&#xff08; …