大话设计模式——24.迭代器模式(Iterator Pattern)

简介

提供一种方法顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部实现。(Java中使用最多的设计模式之一)

UML图
应用场景
  • Java的集合对象:Collection、List、Map、Set等都有迭代器
  • Java ArrayList的迭代器源码

示例

简单实现集合中的迭代器功能

  1. Iterator:
java 复制代码
public interface Iterator {


    /**
     * 是否有下个元素
     *
     * @return
     */
    boolean hasNext();

    /**
     * 当前元素
     *
     * @return
     */
    Object next();

    /**
     * 删除元素
     *
     * @param obj
     */
    void remove(Object obj);
}
java 复制代码
public class ListIterator implements Iterator {


    private List list;

    /**
     * 索引
     */
    private int index = 0;

    public ListIterator(List list) {
        this.list = list;
    }

    @Override
    public boolean hasNext() {
        return index != list.size();
    }

    @Override
    public Object next() {
        Object obj = null;
        if (hasNext()) {
            obj = list.get(index);
            index++;
        }
        return obj;
    }

    @Override
    public void remove(Object obj) {
        list.remove(obj);
    }
}
  1. Aggregate:
java 复制代码
public interface ICollection {

    /**
     * 添加元素
     *
     * @param obj
     */
    void add(Object obj);

    /**
     * 删除元素
     *
     * @param obj
     */
    void remove(Object obj);

    /**
     * 迭代元素
     *
     * @return
     */
    Iterator iterator();
}
java 复制代码
public class ListCollection implements ICollection {

    private List list = new ArrayList();

    @Override
    public void add(Object obj) {
        list.add(obj);
    }

    @Override
    public void remove(Object obj) {
        list.remove(obj);
    }

    @Override
    public Iterator iterator() {
        return new ListIterator(list);
    }
}

3.运行

java 复制代码
public class Main {

    public static void main(String[] args) {
        ListCollection listCollection = new ListCollection();
        listCollection.add("aaaaaa");
        listCollection.add("bbbbbb");
        listCollection.add("cccccc");
        listCollection.add("dddddd");

        // 创建迭代器
        Iterator iterator = listCollection.iterator();
        while (iterator.hasNext()) {
            System.out.println(iterator.next());
        }
    }
}

总结

  • 优点

    • 可以不暴露集合的内部结构,又可让外部代码透明地访问集合内部的数据
    • 支持以不同的方式遍历一个聚合对象
  • 缺点

    • 对于比较简单的遍历如数组、有序列表,该方式实现比较繁琐
    • 在遍历的同时更改迭代器所在的集合结构会导致异常
相关推荐
艾利克斯冰15 小时前
Java 设计模式-行为型模式(更新中)
java·开发语言·设计模式
星心源七境19 小时前
七境体系全解析:从六韬兵法到AI锁颜,一套贯穿古典智慧与现代应用的成长操作系统
人工智能·设计模式·设计
qq_2975746721 小时前
设计模式系列文章(基础篇第21篇):迭代器模式——遍历聚合解耦,实现统一迭代访问
设计模式·迭代器模式
禅思院1 天前
前端请求取消与调度完全指南:从 AbortController 到企业级优先级架构
前端·设计模式·前端框架
小bo波1 天前
用匿名内部类优雅地计算方法执行时间
java·设计模式·性能测试·模板方法模式·lambda·代码优化·匿名内部类
写代码的小阿帆1 天前
行为型设计模式之观察者(发布-订阅)模式
设计模式
王_teacher1 天前
23种设计模式全解析(GoF 设计模式)
设计模式·软考·软件设计师·软考中级
阿坤带你走近大数据1 天前
分别介绍下java主流的开发框架、设计模式与对应编程语言的高级特性
java·开发语言·设计模式
geovindu1 天前
go: Coroutines Pattern
开发语言·后端·设计模式·golang·协程模式
Anastasiozzzz1 天前
构建健壮软件系统的基石:深入解析面向对象设计七大原则
开发语言·javascript·设计模式·ecmascript