二十三种设计模式第十七篇--迭代子模式

news/2024/11/28 23:43:12/

迭代子模式是一种行为型设计模式,它允许你按照特定方式访问一个集合对象的元素,而又不暴露该对象的内部结构。迭代子模式提供了一种统一的方式来遍历容器中的元素,而不需要关心容器的底层实现

该模式包含以下几个关键角色:

迭代器(Iterator):定义遍历集合元素的接口,包括访问下一个元素、判断是否还有元素等方法。
具体迭代器(ConcreteIterator):实现迭代器接口,具体实现遍历集合元素的方法。
容器(Aggregate):定义获取迭代器的方法,一般会返回一个实现了迭代器接口的具体迭代器对象。
具体容器(ConcreteAggregate):实现容器接口,具体实现获取迭代器的方法。
迭代子模式的核心思想是将集合的遍历操作从集合对象中分离出来,使得集合对象只需要关注存储和管理元素的功能。这样做的好处是,使得集合对象的结构变得简单,而且遍历操作的具体实现可以在迭代器中灵活调整,而不需要修改集合对象的代码。

迭代子模式在很多编程语言中都有应用,例如Java中的Iterator接口和.NET中的IEnumerator接口都是迭代子模式的实现。它能够帮助你更方便地遍历集合对象,并且能够使代码更加清晰和可扩展。

在这里插入图片描述

public interface Container<T> {/*** 每个容器中有一个迭代器* @return*/public Iterator iterator();//   public void add( T t);
//
//   public void remove( T t);
//
//   public int size();}
public interface Iterator<T> {/*** 是否有下一个元素* @return*/public boolean hasNext();/*** 提取下一个元素* @return*/public T next();}
/*** 姓名容器,存很多用户的名字,能迭代(循环)*/
public class NameRepository implements Container {public String names[] = {"Robert" , "John" ,"Julie" , "Lora"};/*** 能获取到迭代器* @return*/@Overridepublic Iterator<String> iterator() {return new NameIterator();}/*** 利用内部类做一个迭代器的实现,以完成对   数组的循环..*/private class NameIterator implements Iterator<String> {//index代表当前循环第几个下标的元素了.int index;  //因为当前容器的底层为一个数组, 可以通过索引下标进行迭代@Overridepublic boolean hasNext() {if(  names==null||names.length<=0){return false;}if(index < names.length){return true;}return false;}@Overridepublic String next() {if(this.hasNext()){return names[index++];}return null;}     }
}
public class IteratorPatternDemo {public static void main(String[] args) {//名字的容器NameRepository namesRepository = new NameRepository();//      Iterator ite= namesRepository.iterator();
//      while(  ite.hasNext() ){
//         Object name= ite.next();
//         System.out.println(    name );
//      }for(Iterator<String> iter = namesRepository.iterator(); iter.hasNext();       ){String name = iter.next();System.out.println("Name : " + name);}}
}

迭代子模式适用的场景主要有:

  1. 需要统一遍历不同类型集合对象的方式:如果你有多个类型的集合对象,并且希望以一种统一的方式进行遍历操作,那么迭代子模式可以很好地解决这个问题。通过使用迭代子模式,你可以将遍历操作的实现细节封装在具体迭代器中,从而使得你能够以一种统一的方式遍历所有类型的集合对象。

  2. 希望隐藏集合对象的内部结构:在某些情况下,你可能不希望暴露集合对象的内部结构给客户端代码,而只允许通过特定接口进行遍历和访问。迭代子模式可以帮助你实现这种封装,客户端代码只需要通过迭代器接口与集合对象进行交互,而不需要了解集合对象的具体实现细节。

  3. 需要提供多种遍历方式:迭代子模式可以灵活地支持多种遍历方式,例如正序遍历、逆序遍历、按条件过滤遍历等。通过在具体迭代器中实现不同的遍历方式,你可以根据需要动态切换遍历方式,从而提供更多灵活性和可定制性。

总之,迭代子模式适用于任何需要遍历集合对象的场景,尤其是在需要统一遍历方式、隐藏集合对象内部结构或提供多种遍历方式的情况下。它能够提高代码的可读性、可维护性和可扩展性,并且能够使不同类型的集合对象之间的遍历操作变得更加一致和简单。


http://www.ppmy.cn/news/978017.html

相关文章

跳高比赛1——set-结构体

题目描述 李老师正在分析所有同学参加跳高比赛后的数据&#xff0c;想绘制出身高与跳高成绩之间的关系曲线。 李老师打算先将 n 个同学的数据做一下排序处理&#xff1a; 每个同学都有两项数据&#xff1a;身高 ℎi​&#xff0c;跳高成绩 si​先按跳高成绩 si​ 从大到小排序&…

LeetCode(sql)-0723

聚合函数 620 select * from cinema where mod(id,2)1 and description <> boring order by rating desc1251 select p.product_id, Round(sum(price*units)/sum(units),2)as average_price from UnitsSold u left join Prices p using(product_id) where purchase_d…

MURF20100CT-ASEMI快恢复对管20A 1000V

编辑&#xff1a;ll MURF20100CT-ASEMI快恢复对管20A 1000V 型号&#xff1a;MURF20100CT 品牌&#xff1a;ASEMI 封装&#xff1a;TO-220F 恢复时间&#xff1a;50ns 正向电流&#xff1a;20A 反向耐压&#xff1a;1000V 芯片大小&#xff1a;102MIL*2 芯片个数&…

elasticsearch查询操作(DSL语句方式)

说明&#xff1a;本文介绍在kibana&#xff0c;es的可视化界面上对文档的查询操作&#xff1b; 添加数据 先使用API&#xff0c;创建索引库&#xff0c;并且把数据从MySQL中查出来&#xff0c;传到ES上&#xff0c;参考&#xff08;http://t.csdn.cn/NaTHg&#xff09; 索引库…

SELFIES中的函数简介

import selfies as sf 点进入selfies&#xff0c;可以看到inti中有如下方法&#xff1a; 1、"encoder", >>> import selfies as sf >>> sf.encoder("CCF") [C][C][F] 2、"decoder", >>> import selfies as sf >…

Spring-缓存初步认识

Spring-缓存 简单介绍 缓存是一种介于数据永久存储介质和数据应用之间的数据临时存储介质缓存有效提高读取速度&#xff0c;加速查询效率 spring使用缓存方式 添加依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring…

什么是RESTful API

什么是RESTful API RESTful API是利用HTTP请求访问或使用数据的应用程序接口&#xff08;API&#xff09;的体系结构样式。这些数据可用于GET&#xff0c;PUT&#xff0c;POST和DELETE数据类型&#xff0c;这些数据类型指的是与资源相关的操作读取、更新、创建和删除。 网站的…

vue项目docker docker-compose 本地开发环境配置

配置Docker Compose用于在本地开发Vue项目是一个方便且高效的方法。Docker Compose允许您定义和管理多个容器组成的应用程序。 一、配置Docker Compose文件&#xff0c;用于在本地开发Vue项目 docker-compose.yaml version: 3 services:# Vue应用容器vue-app:build:context: …