设计模式-迭代器模式Iterator(行为型)

迭代器模式

迭代器模式属于行为型模式,用来遍历容器的一种模式。

图解

请添加图片描述

角色

  1. 迭代器接口:定义hasNext方法和next方法
  2. 具体迭代器:实现hasNext方法和next方法
  3. 容器接口:定义返回一个迭代器的接口
  4. 具体容器:实现返回迭代器接口

案例

该案例以简单实现ArrayList和LinkedList来演示迭代器模式。整体思想是,不管是什么容器,必须实现获取迭代器的方法,和定义一个迭代器来遍历对应的容器。

public interface Iterable_<E> {Iterator_<E> iterator();
}public interface Collection_<E> extends Iterable_<E>{void add(E e);int size();
}public interface Iterator_<E> {boolean hasNest();E next();
}

ArrayList实现类

public class ArrayList_<E> implements Collection_<E>{private static final int initSize = 10;private Object [] objects = new Object[initSize];private int index = 0;@Overridepublic void add(E e) {if(index >= objects.length){Object[] newObjects = new Object[(int) (objects.length * 1.5)];System.arraycopy(objects,0,newObjects,0,newObjects.length);this.objects = newObjects;}else {objects[index] = e;}index++;}@Overridepublic int size() {return index;}@Overridepublic Iterator_<E> iterator() {return new ArrayIterator();}/** arrayList迭代器*/private class ArrayIterator<E> implements Iterator_<E>{int cursor;@Overridepublic boolean hasNest() {return cursor != index;}@Overridepublic E next() {E e= (E) objects[cursor];cursor ++;return e;}}
}

linkedList实现类

public class LinkedList_<E> implements Collection_<E>{private int size = 0;private Node<E> lastNode = null;private Node<E> handNode = null;@Overridepublic void add(E e) {Node<E> objectNode =new Node<>(e,null);if(lastNode == null){lastNode = objectNode;handNode = objectNode;}else {lastNode.next = objectNode;lastNode = objectNode;}this.size++;}@Overridepublic int size() {return size;}@Overridepublic Iterator_<E> iterator() {return new LinkedIterator();}private class LinkedIterator implements Iterator_<E>{int cursor = 0;Node<E> tempNode = null;@Overridepublic boolean hasNest() {return cursor != size;}@Overridepublic E next() {cursor++;if(cursor ==1){tempNode = handNode;return handNode.getValue();}else {return tempNode.next.getValue();}}}private class Node<E>{private E value;private Node<E> next;public Node(E value, Node<E> next) {this.value = value;this.next = next;}public void setNext(Node<E> next) {this.next = next;}public E getValue() {return value;}}
}

Test类

package com.shaoby.designpatterns.Iterator;public class Test {public static void main(String[] args) {Collection_<String> objectArrayList_ = new LinkedList_<>();objectArrayList_.add("111");objectArrayList_.add("222");objectArrayList_.add("333");Iterator_<String> iterator = objectArrayList_.iterator();while (iterator.hasNest()){System.out.println(iterator.next());}}
}

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

香橙派AIpro测试SPI通信

香橙派AIpro开发板上有一个SPI接口&#xff0c;如下图红框所示&#xff0c; 系统启动后&#xff0c;其对应的设备是 /dev/spidev0.0 一 硬件回环测试 香橙派AIpro上的系统自带spidev_test工具&#xff0c;非常方便&#xff0c;可以查看其帮助信息&#xff0c;如下&#xff0c…

小红书教程简化版,从0开始走向专业,小红书-主理人培养计划 (13节)

课程目录 1-小红书分析与拆解.mp4 2-小红书电商玩法.mp4 3-小红书基础信息设置10_1.mp4 4-小红书如何开店&#xff1f;.mp4 5-小红书店铺设置&#xff08;1&#xff09;.mp4 5-小红书店铺设置.mp4 6-小红书笔记制作与产品发布.mp4 7-小红书运营的文案与标题.mp4 8-小红…

springboot集成shardingsphere

导入maven依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spr…

Python学习笔记9:入门知识(九)

缩进 什么是缩进&#xff1f; 缩进&#xff0c;简单的理解为本行的首字符相比上一行的首字符位置相对靠后。目前笔者接触的编程语言缩进一般是4字符&#xff0c;直接可以按tab键就行。 为什么突然讲缩进&#xff1f; Python这门语言&#xff0c;是依靠缩进来判断当前行与上…

Java入门4: 泛型和集合

Java入门4: 泛型和集合 MangoGO 芒狗狗 目录 4 泛型和集合4.1 泛型4.2 Collection4.3 List4.4 ArrayList4.5 Map4.6 HashMap4.7 Set 和 HashSet4.8 Collections参考代码4 泛型和集合 Java 使用集合来组织和管理对象,本节我们重点讲解泛型和集合。主要介绍 Collection、List、A…

【数据资源变数据资产之路】数据治理服务解决方案(35页WORD)

引言&#xff1a;随着企业数据量的快速增长和数据来源的多样化&#xff0c;数据治理成为了企业管理的核心议题。数据治理不仅关乎数据的质量、安全性和合规性&#xff0c;还直接影响着企业的决策效率和市场竞争力。为满足企业对高效、规范、安全的数据治理需求&#xff0c;我们…

【仿真建模-anylogic】EventOriginator原理解析

Author&#xff1a;赵志乾 Date&#xff1a;2024-06-16 Declaration&#xff1a;All Right Reserved&#xff01;&#xff01;&#xff01; 1. 类图 2. 原理解析 2.1 核心函数 函数功能double getRest(TimeUnits units)获取剩余时间boolean isActive()判定事件的触发计划是否…

2023年的Top20 AI应用在近一年表现怎么样?

AI应用现在进入寒武纪大爆发时代&#xff0c;百花争艳。如果倒回到2023年初&#xff0c;那时候排名靠前的AI应用在一年多时间&#xff0c;发生了哪些变化&#xff1f;能带给我们什么启示&#xff1f; 在2023年1月&#xff0c;排名靠前20的AI应用是&#xff1a; DeepL&#xff…

JavaScript——初识:JavaScript的组成、输入和输出语句... | JavaScript基础:变量,数据类型转换

目录 初识JavaScript JavaScript的组成 输入和输出语句 ECMAScript 6保留关键字 变量的命名规范 注意事项 JavaScript基础 变量的数据类型 数据类型分类 数据类型转换 转换为字符串型 转换为数字型 转换为布尔型 例题 初识JavaScript JavaScript的组成 Java…

Apache IoTDB进行IoT相关开发实践

当今社会&#xff0c;物联网技术的发展带来了许多繁琐的挑战&#xff0c;尤其是在数据库管理系统领域&#xff0c;比如实时整合海量数据、处理流中的事件以及处理数据的安全性。例如&#xff0c;应用于智能城市的基于物联网的交通传感器可以实时生成大量的交通数据。据估计&…

STM32小项目——震动感应灯

文章目录 前言一、继电器原理1.简单使用说明2.接口说明3.代码实现 二、震动传感器原理1.工作原理2.代码展示 三、项目搭建1.流程构建代码展示 总结 前言 一位学习STM32的小白~ 有错误请评论区或私信指出~ 一、继电器原理 1.简单使用说明 继电器就相当一个开关只不过这个开关…

用Copilot画漫画,Luma AI生成视频:解锁创意新玩法

近年来&#xff0c;随着人工智能技术的不断发展&#xff0c;各种创意工具也层出不穷。今天&#xff0c;我们就来介绍一种全新的创作方式&#xff1a;使用Copilot画漫画&#xff0c;再将漫画放入Luma AI生成视频。 Copilot&#xff1a;你的AI绘画助手 Copilot是一款基于人工智…

C++访问Private,Protecd的一些方法总结

前言 在编写C程序中 我们偶尔会碰到这样的三种特殊修改变量值的需求&#xff1a; [1]在不修改类原本的实现下&#xff0c;访问修改类的Private变量 [2]在不修改类原本的实现下&#xff0c;修改类的Protected变量 Private变量访问 public类模版函数特化 这种办法利用了类模…

解决Qt的multimedia库在clion中依赖库补全的问题

解决Qt的multimedia库在clion中使用报错的问题 在clion中&#xff0c;使用Qt的multimedia库时会报如下错误&#xff1a; defaultServiceProvider::requestService(): no service found for - "org.qt-project.qt.mediaplayer" 我猜测出现这个错误的原因很可能是因为…

区块链中的gas与转账收款相关概念

区块链是一个经济系统 计算与存储系统都是稀缺的&#xff0c;区块链的工作需要消耗资源共识、trustless需要矿工的工作&#xff0c;而矿工需要激励Transaction的执行有成本&#xff08;gas&#xff09;,gas费成为矿工的奖励ether是这个经济生态系统的通行货币 关心的问题 合…

Techo TVP技术 沙龙

Techo TVP技术 沙龙 今天参加了 在上海 徐汇 腾讯云大厦 举办的 Techo TVP 技术沙龙&#xff08;主要介绍 AI agent 让我感受很深&#xff09; &#xff0c;那什么是 AI Agent呢&#xff1f; 是一个智能体&#xff0c;由大语言模型驱动&#xff0c;具有自主理解、感知、规划、…

【react小项目】bmi-calculator

bmi-calculator 目录 bmi-calculator初始化项目01大致布局01代码 02完善样式02代码 03输入信息模块03代码 04 使用图表04代码 05详细记录信息渲染05代码 06 让数据变成响应式的06-1输入框的数据处理06-2图表&#xff0c;和记录信息的区域数据处理 07 删除功能&#xff0c;撤销功…

维度建模中的事实表设计原则

维度建模是一种数据仓库设计方法&#xff0c;其核心是围绕业务过程建立事实表和维度表。事实表主要存储与业务过程相关的度量数据&#xff0c;而维度表则描述这些度量数据的属性。 以下是设计事实表时需要遵循的几个重要原则&#xff0c;来源于《维度建模》那本书上&#xff0…

TCP与UDP案例

udp不会做拆分整合什么的 多大就是多大

STM32学习记录(五)————外部中断EXTI

文章目录 前言一、外部中断EXTI基础知识1.外部中断介绍2.外部中断框架2.1AFIO2. 2.STM32外部中断机制框架 总结 前言 一个学习STM32的小白~ 有问题私信或评论区指出~ 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、外部中断EXTI基础知识 1.外部中…