首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >复习:GoF的23种设计模式之iterator模式(行为型)

复习:GoF的23种设计模式之iterator模式(行为型)

作者头像
营琪
发布2019-12-20 14:39:25
3500
发布2019-12-20 14:39:25
举报
iterator模式(迭代器模式)

就如java集合中的iterator类似,是一种最简单也是最常用的设计模式。它可以让用户通过的特定接口轮询容器中的每一个元素,而不需要了解底层实现。

例如: 遍历一个数组

        int count = 5;
        String[] att = new String[count];
        for (int i = 0; i < count; i++) {
            System.out.println(att[i]);
        }

提问:要是我们的程序需要遍历十个、一百个不同实现的集合,那么我们是否需要编写十个、一百个不同的代码吗?

人类对于处理复杂事请,早已学会分层,将复杂、重复的事请,模块化、精细化、分门别类的处理。对于我们这”一百个不同 “的程序,我们会做的也是分层处理。

答:对于”一百个不同程序“的遍历,我们也进行模块化处理,我们先分析题意:

用户需要遍历”一百个不同的集合“,不想重复编写代码,需要有统一的遍历措施。

“一百个不同集合“需要实现统一的某个模块,或者集合需要包含某个统一遍历措施。

对于解决这个问题,既然是统一某些东西,那么我们可以想到的是 抽象类|接口。让所有集合都实现此接口。

实例代码:

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

abstract class Aggregate {
    abstract Iterator createIterator();
}

class ConcreteAggregate extends Aggregate {
    private int last = 0;
    private String[] str;

    public ConcreteAggregate(int index) {
        this.str = new String[index];
    }

    public String getName(int index) {
        return str[index];
    }

    public void append(String name) {
        str[last] = name;
        last++;
    }

    public int getLast() {
        return last;
    }

    @Override
    Iterator createIterator() {
        return new ConcreteIterator(this);
    }
}

class ConcreteIterator implements Iterator {
    private ConcreteAggregate ca;
    private int index;
    public ConcreteIterator(ConcreteAggregate ca) {
        this.ca = ca;
    }
    public Boolean hasNext() {
        return ca.getLast() > index;
    }

    public Object next() {
        return ca.getName(index);
    }
}

public class iteratorTest {
    public static void main(String[] args) {
        ConcreteAggregate aggregate = new ConcreteAggregate(5);
        aggregate.append("假如一百个程序");
        System.out.println(aggregate.getName(0)+"都是不同的取元素方法");
        aggregate.append("不同的取元素方法");
        Iterator iterator = aggregate.createIterator();
        while (iterator.hasNext()) {
            iterator.next();
        }
    }
}

假如有一百个不同的集合需要遍历,那么编写”一百个集合“都需要继承Aggregate抽象类.

我们遍历时,只需要获取Iterator类,就可以编写一段遍历代码继而重复使用。 不管集合实现如何变化,都可以使用iterator遍历元素,不依赖于aggregate实现类。

UML类图

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

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档