设计模式(014)行为型之迭代器模式

2024-04-11 07:52

本文主要是介绍设计模式(014)行为型之迭代器模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        迭代器模式,用于提供一种方法来顺序访问一个聚合对象中的各个元素,而又不需暴露该对象的内部表示。它将遍历和聚合分离开来,使得可以独立地改变遍历方法而不影响聚合对象。这种模式通常包括一个迭代器接口定义和一个聚合对象接口定义,以及相应的迭代器和聚合对象的实现类。

1、场景设计

实现场景:设计一个迭代器和聚合对象,迭代器依次遍历聚合对象中的数据。

2、C++实现

`ConcreteAggregate`类表示了一个具体的聚合对象,它使用了`std::vector`作为内部存储容器。`ConcreteIterator`类表示了具体的迭代器,它使用了索引来遍历聚合对象中的元素。在`main`函数中,我们创建了一个`ConcreteAggregate`对象并添加了一些元素,然后使用迭代器遍历这些元素并输出它们的值。 

#include <iostream>
#include <vector>// 迭代器接口
class Iterator {public:virtual bool hasNext() const = 0;virtual int next() = 0;
};// 聚合对象接口
class Aggregate {public:virtual Iterator* createIterator() const = 0;virtual void add(int element) = 0;virtual int size() const = 0;virtual int get(int index) const = 0;
};// 具体的迭代器实现
class ConcreteIterator : public Iterator {private:const Aggregate& aggregate;int index;public:ConcreteIterator(const Aggregate& agg) : aggregate(agg), index(0) {}bool hasNext() const override {return index < aggregate.size();}int next() override {return aggregate.get(index++);}
};// 具体的聚合对象实现
class ConcreteAggregate : public Aggregate {private:std::vector<int> elements;public:Iterator* createIterator() const override {return new ConcreteIterator(*this);}void add(int element) override {elements.push_back(element);}int size() const override {return elements.size();}int get(int index) const override {return elements[index];}
};int main() {ConcreteAggregate aggregate;aggregate.add(1);aggregate.add(2);aggregate.add(3);Iterator* iterator = aggregate.createIterator();while (iterator->hasNext()) {std::cout << iterator->next() << " ";}std::cout << std::endl;delete iterator;return 0;
}

3、JAVA实现

`ConcreteAggregate`表示了一个具体的聚合对象,它使用了 Java 的 `ArrayList` 作为内部存储容器。`ConcreteIterator`表示了具体的迭代器,它使用了索引来遍历聚合对象中的元素。在 `main` 方法中,我们创建了一个 `ConcreteAggregate` 对象并添加了一些元素,然后使用迭代器遍历这些元素并输出它们的值。 

package behavioralpattern.iterator;
import java.util.ArrayList;
import java.util.List;public class IteratorDemo {// 迭代器接口interface Iterator {boolean hasNext();int next();}// 聚合对象接口interface Aggregate {Iterator createIterator();}// 具体迭代器类static class ConcreteIterator implements Iterator {private List<Integer> elements;private int position;ConcreteIterator(List<Integer> elements) {this.elements = elements;this.position = 0;}public boolean hasNext() {return position < elements.size();}public int next() {return elements.get(position++);}}// 具体聚合对象类static class ConcreteAggregate implements Aggregate {private List<Integer> elements;ConcreteAggregate() {elements = new ArrayList<>();}public void add(int element) {elements.add(element);}public Iterator createIterator() {return new ConcreteIterator(elements);}}public static void main(String[] args) {ConcreteAggregate aggregate = new ConcreteAggregate();aggregate.add(1);aggregate.add(2);aggregate.add(3);Iterator iterator = aggregate.createIterator();while (iterator.hasNext()) {System.out.print(iterator.next() + " ");}}
}

这篇关于设计模式(014)行为型之迭代器模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/893498

相关文章

SpringBoot如何通过Map实现策略模式

《SpringBoot如何通过Map实现策略模式》策略模式是一种行为设计模式,它允许在运行时选择算法的行为,在Spring框架中,我们可以利用@Resource注解和Map集合来优雅地实现策略模式,这... 目录前言底层机制解析Spring的集合类型自动装配@Resource注解的行为实现原理使用直接使用M

Mybatis从3.4.0版本到3.5.7版本的迭代方法实现

《Mybatis从3.4.0版本到3.5.7版本的迭代方法实现》本文主要介绍了Mybatis从3.4.0版本到3.5.7版本的迭代方法实现,包括主要的功能增强、不兼容的更改和修复的错误,具有一定的参考... 目录一、3.4.01、主要的功能增强2、selectCursor example3、不兼容的更改二、

C#原型模式之如何通过克隆对象来优化创建过程

《C#原型模式之如何通过克隆对象来优化创建过程》原型模式是一种创建型设计模式,通过克隆现有对象来创建新对象,避免重复的创建成本和复杂的初始化过程,它适用于对象创建过程复杂、需要大量相似对象或避免重复初... 目录什么是原型模式?原型模式的工作原理C#中如何实现原型模式?1. 定义原型接口2. 实现原型接口3

kotlin中的行为组件及高级用法

《kotlin中的行为组件及高级用法》Jetpack中的四大行为组件:WorkManager、DataBinding、Coroutines和Lifecycle,分别解决了后台任务调度、数据驱动UI、异... 目录WorkManager工作原理最佳实践Data Binding工作原理进阶技巧Coroutine

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序