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

2023-03-29 15:30:43 浏览数 (1)

文章目录

  • 一、迭代器模式简介
  • 二、迭代器模式适用场景
  • 三、迭代器模式优缺点
  • 四、迭代器模式和访问者模式
  • 五、迭代器模式代码示例
    • 1、迭代器接口
    • 2、迭代器实现
    • 3、集合元素实例类
    • 4、集合管理接口
    • 5、集合管理实现类
    • 6、测试类

一、迭代器模式简介


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

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

二、迭代器模式适用场景


迭代器模式适用场景 :

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

三、迭代器模式优缺点


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

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

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


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

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

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

五、迭代器模式代码示例


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

1、迭代器接口

代码语言:javascript复制
package iterator;

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

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

2、迭代器实现

代码语言:javascript复制
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、集合元素实例类

代码语言:javascript复制
=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、集合管理接口

代码语言:javascript复制
package iterator;

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

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

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

5、集合管理实现类

代码语言:javascript复制
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、测试类

代码语言:javascript复制
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);
        }
    }
}

执行结果 :

代码语言:javascript复制
返回 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'}

0 人点赞