迭代器模式(Iterator Pattern)

这篇具有很好参考价值的文章主要介绍了迭代器模式(Iterator Pattern)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

迭代器模式(Iterator Pattern)

一、定义

提供一种方法顺序访问一个聚合对象中各个元素,而又不需要暴露该对象的内部表示。

二、优缺点

优点: 1、它支持以不同的方式遍历一个聚合对象。 2、迭代器简化了聚合类。 3、在同一个聚合上可以有多个遍历。 4、在迭代器模式中,增加新的聚合类和迭代器类都很方便,无须修改原有代码。

缺点: 1、由于迭代器模式将存储数据和遍历数据的职责分离,增加新的聚合类需要对应增加新的迭代器类,类的个数成对增加,这在一定程度上增加了系统的复杂性。

三、具体实现

3.1 原型图

迭代器模式(Iterator Pattern)
  1. Iterator(迭代器):迭代器定义访问和遍历元素的接口。
  2. ConcreteIterator(具体迭代器):具体迭代器实现迭代器接口,对该聚合遍历时跟踪当前位置。
  3. Aggregate(聚合):聚合定义创建相应迭代器对象的接口。
  4. ConcreteAggregate(具体聚合):具体聚合实现创建相应迭代器的接口,该操作返回ConcreteIterator的一个适当的实例。

3.2 实现
1、创建接口:

/**
 * @author zhongtao
 * @date 2023/6/17 18:48
 */
public interface Iterator {
    public boolean hasNext();

    public Object next();
}

/**
 * @author zhongtao
 * @date 2023/6/17 18:48
 */
public interface Container {
    public Iterator getIterator();
}

2、创建实现了 Container 接口的实体类。该类有实现了 Iterator 接口的内部类 NameIterator。

/**
 * @author zhongtao
 * @date 2023/6/17 18:48
 */
public class NameRepository implements Container {
   public String[] names = {"1" , "1" ,"1" , "1"};
 
   @Override
   public Iterator getIterator() {
      return new NameIterator();
   }
 
   private class NameIterator implements Iterator {
 
      int index;
 
      @Override
      public boolean hasNext() {
         if(index < names.length){
            return true;
         }
         return false;
      }
 
      @Override
      public Object next() {
         if(this.hasNext()){
            return names[index++];
         }
         return null;
      }     
   }
}

3、使用 NameRepository 来获取迭代器,并打印名字。

/**
 * @author zhongtao
 * @date 2023/6/17 18:49
 */
public class IteratorPatternDemo {

    public static void main(String[] args) {
        NameRepository namesRepository = new NameRepository();

        for (Iterator iter = namesRepository.getIterator(); iter.hasNext(); ) {
            String name = (String) iter.next();
            System.out.println("Name : " + name);
        }
    }
}

4、执行程序,输出结果:文章来源地址https://www.toymoban.com/news/detail-487709.html

Name : 1
Name : 2
Name : 3
Name : 4

到了这里,关于迭代器模式(Iterator Pattern)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 设计模式——迭代器模式(Iterator Pattern)+ Spring相关源码

    类型: 行为型模式 目的: 用于顺序访问集合对象的元素,使用者不需要知道集合对象的底层表示。 2.1.1 定义迭代器接口 2.1.2 定义迭代对象接口——用于返回一个迭代器 2.1.3 实现 迭代对象 和 迭代器 2.1.4 使用 迭代器CompositeIterator 创建型模式 结构型模式 1、设计模式——装

    2024年02月05日
    浏览(44)
  • (三)行为模式:4、迭代器模式(Iterator Pattern)(C++示例)

    目录 1、迭代器模式(Iterator Pattern)含义 2、迭代器模式的UML图学习 3、迭代器模式的应用场景 4、迭代器模式的优缺点 (1)优点 (2)缺点 5、C++实现迭代器模式的实例 1、迭代器模式(Iterator Pattern)含义 迭代器模式(Iterator),提供一种方法顺序访问一个聚合对象中各个元

    2024年02月11日
    浏览(35)
  • java常见面试题:什么是迭代器模式(Iterator Pattern)?如何实现迭代器模式?

    迭代器模式(Iterator Pattern)是设计模式中的一种,它提供了一种顺序访问一个聚合对象(如列表、集合等)中各个元素的方法,而又不需要暴露该对象的内部表示。使用迭代器模式,可以方便地遍历一个聚合对象的所有元素,而不需要了解该对象的底层结构。 迭代器模式主

    2024年01月18日
    浏览(55)
  • 设计模式第16讲——迭代器模式(Iterator)

    迭代器模式是一种 行为型 设计模式,它提供了一种 统一的方式来访问集合对象中的元素,而不是暴露集合内部的表示方式 。简单地说,就是将遍历集合的责任封装到一个单独的对象中,我们可以按照特定的方式访问集合中的元素。 抽象迭代器(Iterator):定义了遍历聚合对

    2024年02月11日
    浏览(46)
  • 设计模式之迭代器模式(Iterator)的C++实现

    在软件开发过程中,操作的集合对象内部结构常常变化,在访问这些对象元素的同时,也要保证对象内部的封装性。迭代器模式提供了一种利用面向对象的遍历方法来遍历对象元素。迭代器模式通过抽象一个迭代器类,不同的对象继承自迭代器类,外部通过统一接口访问元素

    2024年02月11日
    浏览(47)
  • 迭代器模式(Interator Pattern)

    迭代器模式(Iterator Pattern)是一种使用频率非常高的行为型设计模式, 迭代器 用于 对一个聚合对象进行遍历 。通过 引入迭代器 可以 将数据的遍历功能从聚合对象中分离出来 , 聚合对象只负责存储数据 ,而 遍历数据由迭代器来完成 ,简化了聚合对象的设计,更符合“单

    2024年02月05日
    浏览(68)
  • 【设计模式——学习笔记】23种设计模式——迭代器模式Iterator(原理讲解+应用场景介绍+案例介绍+Java代码实现)

    编写程序展示一个学校院系结构: 需求是这样,要在一个页面中展示出学校的院系组成,一个学校有多个学院,一个学院有多个系 【传统方式】 将学院看做是学校的子类,系是学院的子类,小的组织继承大的组织 分析: 在一个页面中展示出学校的院系组成,一个学校有多个

    2024年02月14日
    浏览(42)
  • C++设计模式_21_Iterator 迭代器(理解;面向对象的迭代器已过时;C++中使用泛型编程的方式实现)

    Iterator 迭代器也是属于“数据结构”模式。 GoF中面向对象的迭代器已经过时,C++中目前使用泛型编程的方式实现,其他语言还在使用面向对象的迭代器。 在软件构建过程中,集合对象内部结构常常变化各异。但对于这些集合对象,我们希望在不暴露其内部结构的同时,可以

    2024年02月07日
    浏览(57)
  • <Java Iterator> 迭代器Iterator双层循环

    案例分享: 测试输出:

    2024年02月15日
    浏览(43)
  • <Java Iterator> 迭代器Iterator双层循环 案例分享

    需求: 需要一个按钮,每次执行的时候,调接口刷新数据库表中的数据: 刷新条件: 如果接口获取的数据和数据库表的数据完全一致则不刷新,如果不一致,则新增数据;

    2024年02月15日
    浏览(84)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包