设计模式迭代器模式 ( 简介 | 适用场景 | 优缺点 | 代码示例 )

Posted 韩曙亮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了设计模式迭代器模式 ( 简介 | 适用场景 | 优缺点 | 代码示例 )相关的知识,希望对你有一定的参考价值。





一、迭代器模式简介



迭代器模式 : 提供一种方法 , 顺序访问 集合对象 中的 各个元素 , 而 不暴露 该对象 的内部表示 ;


迭代器模式类型 : 行为型 ;





二、迭代器模式适用场景



迭代器模式适用场景 :

  • 内容保密 : 访问 集合对象 的内容 , 无需暴露内部表示 ;
  • 统一接口 : 为遍历 不同的 集合结构 , 提供统一接口 ;




三、迭代器模式优缺点



迭代器模式优点 : 分离 了 集合对象 的 遍历行为 ; 抽象出了 迭代器 负责 集合对象的遍历 , 可以让外部的代码 透明的 访问集合内部的数据 ;


迭代器模式缺点 : 类的个数成对增加 ; 迭代器模式 , 将 存储数据 , 遍历数据 两个职责拆分 ; 如果新添加一个 集合类 , 需要增加该 集合类 对应的 迭代器类 , 类的个数成对增加 , 在一定程度上 , 增加了系统复杂性 ;





四、迭代器模式和访问者模式



迭代器模式和访问者模式 : 两个模式都是 迭代地 访问集合对象中的元素 ,

  • 访问者模式 : 访问者模式 中 , 扩展开放的部分 , 作用于对象的操作上 ;
  • 迭代器模式 : 迭代器模式 中 , 扩展开放的部分 , 是在对象的种类上 ;

迭代器模式 , 应用广泛 , 但是基本都使用 JDK 中提供的迭代器 , 不需要自己实现 ;





五、迭代器模式代码示例



业务场景 : 使用迭代器模式 , 管理多个学生的信息 ;


1、迭代器接口


package iterator;

public interface StudentIterator {
    /**
     * 获取下一个学生对象
     * @return
     */
    Student nextStudent();

    /**
     * 是否是最后一个
     * @return
     */
    boolean isLast();
}

2、迭代器实现


package iterator;

import java.util.ArrayList;

public class StudentIteratorImpl implements StudentIterator{
    /**
     * 学生集合, 通过构造函数注入
     */
    private ArrayList<Student> list;

    /**
     * 当前处理的集合索引
     */
    private int position;

    /**
     * 当前处理的学生对象
     */
    private Student student;

    public StudentIteratorImpl(ArrayList<Student> list) {
        this.list = list;
    }

    @Override
    public Student nextStudent() {
        System.out.println("返回 " + position + " 位置的学生对象 : " + student);
        student = list.get(position);
        position++;
        return student;
    }

    @Override
    public boolean isLast() {
        return position < list.size() ? false : true;
    }
}

3、集合元素实例类


=package iterator;

public class Student {
    String name;

    public Student(String name) {
        this.name = name;
    }

    public String getName() {
        return name;
    }

    @Override
    public String toString() {
        return "Student{" +
                "name='" + name + '\\'' +
                '}';
    }
}

4、集合管理接口


package iterator;

/**
 * 集合的管理类
 */
public interface StudentAggregate {
    /**
     * 增加学生
     * @param student
     */
    void addStudent(Student student);

    /**
     * 删除学生
     */
    void removeStudent(Student student);

    /**
     * 获取学生集合的迭代器
     * @return
     */
    StudentIterator getStudentIterator();
}

5、集合管理实现类


package iterator;

import java.util.ArrayList;

/**
 * 维护集合
 */
public class StudentAggregateImpl implements StudentAggregate{
    /**
     * 学生集合
     */
    private ArrayList<Student> list;

    public StudentAggregateImpl() {
        this.list = new ArrayList<>();
    }

    @Override
    public void addStudent(Student student) {
        this.list.add(student);
    }

    @Override
    public void removeStudent(Student student) {
        this.list.remove(student);
    }

    @Override
    public StudentIterator getStudentIterator() {
        return new StudentIteratorImpl(this.list);
    }
}

6、测试类


package iterator;

public class Main {
    public static void main(String[] args) {
        // 创建 3 个学生对象
        Student tom = new Student("Tom");
        Student jerry = new Student("Jerry");
        Student trump = new Student("Trump");

        // 构造学生对象集合
        StudentAggregate studentAggregate = new StudentAggregateImpl();
        studentAggregate.addStudent(tom);
        studentAggregate.addStudent(jerry);
        studentAggregate.addStudent(trump);

        // 获取学生对象的迭代器
        StudentIterator studentIterator = studentAggregate.getStudentIterator();
        // 判断是否是最后一个对象 , 如果不是 , 获取下一个对象 , 并打印
        while (!studentIterator.isLast()) {
            Student student = studentIterator.nextStudent();
            System.out.println(student);
        }

        // 删除一个对象
        studentAggregate.removeStudent(trump);
        System.out.println("删除 Trump" );

        studentIterator = studentAggregate.getStudentIterator();
        // 判断是否是最后一个对象 , 如果不是 , 获取下一个对象 , 并打印
        while (!studentIterator.isLast()) {
            Student student = studentIterator.nextStudent();
            System.out.println(student);
        }
    }
}

执行结果 :

返回 0 位置的学生对象 : null
Student{name='Tom'}
返回 1 位置的学生对象 : Student{name='Tom'}
Student{name='Jerry'}
返回 2 位置的学生对象 : Student{name='Jerry'}
Student{name='Trump'}
删除 Trump
返回 0 位置的学生对象 : null
Student{name='Tom'}
返回 1 位置的学生对象 : Student{name='Tom'}
Student{name='Jerry'}

以上是关于设计模式迭代器模式 ( 简介 | 适用场景 | 优缺点 | 代码示例 )的主要内容,如果未能解决你的问题,请参考以下文章

设计模式课程 设计模式精讲 18-1 迭代器模式讲解

迭代器模式(Iterator Pattern)

《javascript高级程序设计》学习笔记 | 7.2.迭代器模式

设计模式-迭代器模式

设计模式之迭代器模式

B10:迭代器模式 Iterator