前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >小谈设计模式(21)—迭代器模式

小谈设计模式(21)—迭代器模式

作者头像
学编程的小程
发布2023-10-11 16:16:18
1310
发布2023-10-11 16:16:18
举报
文章被收录于专栏:学习笔记ol学习笔记ol
小谈设计模式(21)—迭代器模式

专栏介绍

主要对目前市面上常见的23种设计模式进行逐一分析和总结,希望有兴趣的小伙伴们可以看一下,会持续更新的。希望各位可以监督我,我们一起学习进步,加油,各位。

在这里插入图片描述
在这里插入图片描述

迭代器模式

迭代器模式是一种行为型设计模式,它提供了一种访问聚合对象中各个元素的方法,而不需要暴露聚合对象的内部表示。迭代器模式将遍历元素的责任交给迭代器对象,从而简化了聚合对象的接口。

在这里插入图片描述
在这里插入图片描述

对象分析

聚合对象(Aggregate)

聚合对象是包含一组元素的对象,它通常提供一个创建迭代器的方法。聚合对象可以是一个集合、数组、列表等。聚合对象的主要职责是通过迭代器对象提供对元素的遍历。

在这里插入图片描述
在这里插入图片描述
迭代器对象(Iterator)

迭代器对象负责遍历聚合对象中的元素。它通常包含一些基本的方法,如获取下一个元素、判断是否还有下一个元素等。迭代器对象可以根据具体的需求实现不同的遍历方式,如正向遍历、逆向遍历等。

在这里插入图片描述
在这里插入图片描述

Java程序示例

代码语言:javascript
复制
// 聚合对象
public interface Aggregate {
    Iterator createIterator();
}

// 具体的聚合对象
public class ConcreteAggregate implements Aggregate {
    private List<Object> items = new ArrayList<>();

    public void addItem(Object item) {
        items.add(item);
    }

    public Iterator createIterator() {
        return new ConcreteIterator(items);
    }
}

// 迭代器对象
public interface Iterator {
    boolean hasNext();
    Object next();
}

// 具体的迭代器对象
public class ConcreteIterator implements Iterator {
    private List<Object> items;
    private int position = 0;

    public ConcreteIterator(List<Object> items) {
        this.items = items;
    }

    public boolean hasNext() {
        return position < items.size();
    }

    public Object next() {
        Object item = items.get(position);
        position++;
        return item;
    }
}

// 使用迭代器模式
public class Main {
    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);
        }
    }
}
在这里插入图片描述
在这里插入图片描述
程序分析
1

在上述示例中,Aggregate 接口定义了创建迭代器的方法 createIterator,ConcreteAggregate 是具体的聚合对象,实现了 createIterator 方法,返回具体的迭代器对象 ConcreteIterator。ConcreteIterator 实现了 Iterator 接口,提供了遍历聚合对象中元素的功能。

2

在 Main 类中,我们创建了一个具体的聚合对象 ConcreteAggregate,添加了一些元素。然后通过 createIterator 方法创建了一个迭代器对象,并使用 while 循环遍历聚合对象中的元素。

在这里插入图片描述
在这里插入图片描述

优缺点分析

优点
简化了聚合对象的接口

迭代器模式将遍历聚合对象的责任封装在迭代器对象中,使得聚合对象的接口更加简洁,只需要提供一个创建迭代器的方法即可。

统一的遍历方式

迭代器模式提供了一种统一的遍历方式,无论聚合对象的内部结构如何变化,都可以通过迭代器对象进行遍历,使得客户端代码更加简洁和可读。

增加了代码的可读性和可维护性

迭代器模式将遍历逻辑封装在迭代器对象中,使得代码的逻辑更加清晰,易于理解和维护。

缺点
增加了系统的复杂性

引入迭代器模式会增加系统的类和对象的数量,增加了系统的复杂性。

迭代器的实现可能会受到聚合对象的影响

迭代器的实现通常依赖于聚合对象的内部结构,如果聚合对象的结构发生变化,可能需要相应地修改迭代器的实现。

不适合对于某些特殊聚合对象的遍历

迭代器模式适用于遍历聚合对象的情况,但对于某些特殊的聚合对象,如树形结构,可能需要使用其他遍历方式。

总结

迭代器模式通过封装遍历聚合对象的责任,简化了聚合对象的接口,提供了一种统一的遍历方式,增加了代码的可读性和可维护性。然而,迭代器模式也会增加系统的复杂性,可能受到聚合对象的影响,并且不适用于某些特殊聚合对象的遍历。因此,在使用迭代器模式时需要权衡其优缺点,根据具体情况进行选择。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-10-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 小谈设计模式(21)—迭代器模式
  • 专栏介绍
  • 迭代器模式
    • 对象分析
      • 聚合对象(Aggregate)
      • 迭代器对象(Iterator)
    • Java程序示例
      • 程序分析
    • 优缺点分析
      • 优点
      • 缺点
      • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档