迭代器设计模式示例

本文是我们名为“ 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

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

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

相关文章

uibinder表单提交_使用UIBinder的GWT自定义按钮

uibinder表单提交这是一个有关如何在GWT上使用UIBinder创建自定义按钮的示例。 public class GwtUIBinderButton implements EntryPoint {public void onModuleLoad() {Button button new Button();button.setText("Button");button.addClickHandler(new ClickHandl…

python用import xlwt出现红字_如何用python处理excel

最近看到有很多的python课程是教人怎么用python处理excel,我看了一下价格收费还贼高...这么初级毫无水平的操作我的粉丝们就不要花钱去报课程了..我免费教你们怎么做.首先我们先要安装两个模块,一个叫做xlrd,一个是xlwt.安装如下:打开cmd输入pip install xlrd等待安装成功,成功…

什么是升职率?

我确实相信您熟悉彼得原则 。 一般而言&#xff0c;该原则是一种观察&#xff0c;即晋升可能并且将导致晋升人员不再符合该职位的条件。 对于JVM&#xff0c;存在类似的问题。 太快地提升对象可能会对性能产生重大影响。 在这篇文章中&#xff0c;我们将探讨提升率的概念&…

mysql自增id用完了_MySQL表自增id用完了该怎么办?

我们知道MySQL表可以定义一个自增长的id&#xff0c;如果我们的表没有指定主键字段&#xff0c;那MySQL会给我们的表创建一个不可见的&#xff0c;长度为6个自己的row_id&#xff0c;然后不停地往上加步长&#xff0c;虽然生活中自然数是没有上限的&#xff0c;但是在计算机里&…

jmeter插件监控cpu小节点

JMeter使用plugins插件进行服务器性能监控 性能测试时&#xff0c;我们的关注点有两部分 1 服务本身&#xff1a;并发响应时间 QPS 2 服务器的资源使用情况&#xff1a;cpu memory I/O disk等 JMeter的plugins插件可以实现对"二"的监控&#xff0c;具体操作步骤如下(…

mysql写入监控_zabbix监控mysql操作

说明&#xff1a;配置zabbix自带Mysql模板# 创建目录mkdir /var/lib/zabbix# 创建连接数据库文件touch /var/lib/zabbix/.my.cnf# 写入数据连接信息[client]host 192.168.0.148user rootpassword 123dffsdfs# 创建监控项文件touch /etc/zabbix/zabbix_agentd.conf.d/userpar…

openshift_云上的播放框架变得简单:Openshift模块

openshift仅仅几年前&#xff0c;找到一个负担得起的Java Web应用程序托管解决方案是一项艰巨的任务&#xff0c;而寻找免费的托管解决方案是一项不可能的任务。 更不用说考虑自动缩放&#xff0c;单命令部署&#xff0c;持续集成等问题了&#xff0c;这简直就是科幻小说。 去年…

xclock 不出来界面_macOS 使用 XQuartz 支持 X11 实现 Linux 图形化界面显示

更多奇技淫巧欢迎订阅博客&#xff1a;https://fuckcloudnative.io前言在 Windows 中相信大家已经很熟悉使用 Xmanager(Xshell), MobaXterm, SecureCRT 通过 X11 实现 Linux 图形化界面显示&#xff0c;我的需求是在 macOS 下使用 iTerm2 作为 Terminal 实现 X11 图形化界面显示…

命令设计模式示例

本文是我们名为“ Java设计模式 ”的学院课程的一部分。 在本课程中&#xff0c;您将深入研究大量的设计模式&#xff0c;并了解如何在Java中实现和利用它们。 您将了解模式如此重要的原因&#xff0c;并了解何时以及如何应用模式中的每一个。 在这里查看 &#xff01; 目录 …

ArcGIS API for Silverlight 调用GP服务准备---GP模型建立、发布、测试

ArcGIS API for Silverlight 调用GP服务准备---GP模型建立、发布、测试 原文:ArcGIS API for Silverlight 调用GP服务准备---GP模型建立、发布、测试第一篇、GP降雨量等值线建模、发布及测试在水利、气象等行业中&#xff0c;要在WebGIS中实现空间分析功能&#xff0c;如绘制等…

win10企业版更新和安全中没有 “恢复”这个选项_通知:微软已强制对Windows 10更新升级...

最近&#xff0c;微软发布了Windows10的强制升级。从本月开始&#xff0c;如果您的个人电脑、笔记本电脑和其他设备没有手动升级&#xff0c;微软将强制部分用户升级到Windows10 1909或2004版本。原因很简单。微软已经停止支持Windows10 1903版&#xff08;包括家庭版和专业版&…

docker 多个mysql_mysql8.0 利用docker容器安装配置多主多从集群

1. 在/user/local/share/下创建mysql文件夹&#xff0c;在mysql文件夹目录下创建4个文件夹分别是:master1, master2, slave1, slave2分别在每个目录下建立data, conf, logs用于数据持久化创建后如下2.创建容器&#xff1a;1)创建一个名为master1的mysql容器(主 mysql)docker ru…

JavaFX 2.0和Scala,例如牛奶和饼干

JavaFX 2.0和Scala都是很好的技术&#xff0c;但是一起使用时效果会更好。 JavaFX 2.0是一种功能强大的富客户端技术&#xff0c;具有先进的图形&#xff0c;动画和媒体功能。 Scala是一种简单但功能强大的语言&#xff0c;具有用于编写特定于域的语言&#xff08;DSL&#xff…

thinkphp+mysql+join+where_thinkphp5.0 多join时where无法between

情况类似于这个链接,这帖子的老哥没有答案,现在遇到一样的问题了,下面贴上代码$map [products.insurance_status>1];//是否计算下线的产品if( input(get.times) && input(get.times) < 7 ){$time return_times(input(get.times));//此处有bug$map[order.pay_ti…

访客设计模式示例

本文是我们名为“ Java设计模式 ”的学院课程的一部分。 在本课程中&#xff0c;您将深入研究大量的设计模式&#xff0c;并了解如何在Java中实现和利用它们。 您将了解模式如此重要的原因&#xff0c;并了解何时以及如何应用模式中的每一个。 在这里查看 &#xff01; 目录 …

报名照片审核处理工具_太浦军考|2020年文职人员报名照片审核程序,照片处理工具应该如何使用?...

考文职 找太浦 最靠谱照片处理工具使用说明01注意&#xff1a;一、本工具是报名照片审核处理工具&#xff0c;只有通过该审核工具审核通过的照片才能在注册时正常上传。照片将应用在准考证和合格证书中。二、源文件必须是标准证件数字照片&#xff0c;JPG或JPEG格式&#xff0c…

python 比赛成绩预测_Python预测NBA比赛结果

下载W3Cschool手机App&#xff0c;0基础随时随地学编程导语利用Python简单地预测一下NBA比赛结果。。。这大概就叫蹭热度吧。。。毕竟貌似今天朋友圈都在刷NBA相关的内容。。。虽然我并不能看懂。。。但这并不妨碍我瞎预测一波。。。So,以下内容纯属瞎玩&#xff0c;如有雷同&a…

适配器设计模式示例

本文是我们名为“ Java设计模式 ”的学院课程的一部分。 在本课程中&#xff0c;您将深入研究大量的设计模式&#xff0c;并了解如何在Java中实现和利用它们。 您将了解模式如此重要的原因&#xff0c;并了解何时以及如何应用模式中的每一个。 在这里查看 &#xff01; 目录 …

cesium鼠标控制键盘_Cesium中级教程3 - Camera - 相机(摄像机)

CameraCesiumJS中的Camera控制场景的视图。有很多方法可以操作Camera&#xff0c;如旋转(rotate)、缩放(zoom)、平移(pan)和飞到目的地(flyTo)。CesiumJS有鼠标和触摸事件用来处理与Camrea的交互&#xff0c;还有API来以编程方式操作摄像机。了解如何使用Camera API和自定义相机…

windows下统一mysql编码_mysql5.7 windows7编码统一utf-8

查看mysql数据编码登录mysql服务&#xff0c;查看mysql数据库默认的编码mysql> show variables like character%;---------------------------------------------------------------------------| Variable_name | Value |------------------------------------------------…