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

java实现迭代器模式

迭代器模式(Iterator Pattern)是一种行为型设计模式,它提供一种方法来顺序访问一个聚合对象(如列表、集合、数组等)中的元素,而不暴露聚合对象的内部表示。迭代器模式通常包括以下角色:迭代器(Iterator)、具体迭代器(Concrete Iterator)、聚合(Aggregate)、具体聚合(Concrete Aggregate)。

以下是一个简单的Java示例,演示如何实现迭代器模式:

首先,定义迭代器接口 Iterator,它包括用于访问元素的方法:

public interface Iterator {boolean hasNext();Object next();
}

然后,定义聚合接口 Aggregate,它包括创建迭代器的方法:

public interface Aggregate {Iterator createIterator();
}

接下来,创建具体聚合类 ConcreteAggregate,实现 Aggregate 接口,并包括一个内部数据结构(例如数组或列表):

import java.util.ArrayList;
import java.util.List;public class ConcreteAggregate implements Aggregate {private List<Object> items = new ArrayList<>();public void addItem(Object item) {items.add(item);}@Overridepublic Iterator createIterator() {return new ConcreteIterator(this);}public Object getItem(int index) {return items.get(index);}public int size() {return items.size();}
}

然后,创建具体迭代器类 ConcreteIterator,实现 Iterator 接口,并维护一个对聚合对象的引用以访问元素:

public class ConcreteIterator implements Iterator {private ConcreteAggregate aggregate;private int currentIndex = 0;public ConcreteIterator(ConcreteAggregate aggregate) {this.aggregate = aggregate;}@Overridepublic boolean hasNext() {return currentIndex < aggregate.size();}@Overridepublic Object next() {if (hasNext()) {return aggregate.getItem(currentIndex++);}throw new NoSuchElementException();}
}

最后,我们可以使用迭代器模式来顺序访问聚合对象中的元素:

public class IteratorPatternDemo {public static void main(String[] args) {ConcreteAggregate aggregate = new ConcreteAggregate();aggregate.addItem("Item 1");aggregate.addItem("Item 2");aggregate.addItem("Item 3");Iterator iterator = aggregate.createIterator();while (iterator.hasNext()) {Object item = iterator.next();System.out.println("Item: " + item);}}
}

在这个示例中,我们创建了一个具体聚合 ConcreteAggregate,并向其添加了三个元素。然后,我们创建了一个迭代器 ConcreteIterator 来顺序访问聚合中的元素。通过使用迭代器模式,我们可以在不暴露聚合内部结构的情况下遍历聚合对象。

迭代器模式通常用于遍历和访问集合、列表、数组等数据结构,它将遍历算法与数据结构分离,使得算法可以独立变化。这提高了代码的灵活性和可维护性。

http://www.lryc.cn/news/154341.html

相关文章:

  • C++day7模板、异常、auto关键字、lambda表达式、数据类型转换、STL、list、文件操作
  • 【校招VIP】产品分析之活动策划宣传
  • node基础之一:fs 模块
  • 如何快速搭建母婴行业的微信小程序?
  • 【科普向】Jmeter 如何测试接口保姆式教程
  • 阿里云2核4G服务器5M带宽5年费用价格明细表
  • 【图解RabbitMQ-2】图解JMS规范与AMQP协议是什么
  • springboot整合mybatis实现增删改查(xml)--项目阶段1
  • springboot文件上传异步报错
  • error: unable to unlink old ‘.gitlab-ci.yml‘: Permission denied
  • AJAX学习笔记3练习
  • springboot实战(五)之sql业务日志输出,重要
  • redis7.2.0 centos源码编译安装并设置开机自启动
  • 网易低代码引擎Tango正式开源
  • Apache Linkis 与 OceanBase 集成:实现数据分析速度提升
  • EXPLAIN概述与字段剖析
  • 基于Java IO 序列化方案的memcached-session-manager多memcached节点配置
  • LinkedList(3):并发异常
  • vue里el-form+el-table实现验证规则的写法
  • K8S 基础概念学习
  • Java之正则表达式的详细解析
  • 移动端的屏幕分辨率与浏览器的视口宽度(视口大小)是两回事儿
  • 分布式 - 服务器Nginx:基础系列之Nginx静态资源优化配置指令sendfile | tcp_nopush | tcp_nodelay
  • Sentinel配置的blockHandler方法不生效
  • Mybatis的三种映射关系以及联表查询
  • 基于串口校时的数字钟设计
  • 支持向量机(二)
  • Arrays.asList 和 null 类型
  • 《论文阅读》用提示和释义模拟对话情绪识别的思维过程 IJCAI 2023
  • 【AI】机器学习——绪论