《大话设计模式》读书笔记 - 迭代器模式

本文深入解析迭代器模式,介绍其定义、模型、应用及代码实现。迭代器模式提供了一种访问聚合对象的方法,无需暴露其内部结构,支持多种遍历方式,简化聚合类并允许同一聚合上进行多次遍历。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、迭代器模式定义

​ 提供一种方法顺序访问一个聚合对象中各个元素, 而又无须暴露该对象的内部表示

2、迭代器模式模型图

在这里插入图片描述

3、迭代器模式应用

1、它支持以不同的方式遍历一个聚合对象。
2、迭代器简化了聚合类。 
3、在同一个聚合上可以有多个遍历。
4、在迭代器模式中,增加新的聚合类和迭代器类都很方便,无须修改原有代码

迭代器模式在访问数组、集合、列表等数据时,有着非常普遍的使用,由于它太普遍了所以各种语言都对他进行了封装,一般不需要自己实现迭代器相关功能

例如:在Java语言中常用的数据结构内部都提供了Iterator以便于获取元素(集合、数组。。。)

4、代码案例

第一步:创建接口

/**
 * 迭代器接口
 * 定义迭代顺序
 */
public interface Iterator {

    /**
     * 获取迭代顺序的第一个元素
     * @return
     */
    Object first();

    /**
     * 获取迭代顺序的最后一个元素
     * @return
     */
    Object last();

    /**
     * 获取迭代顺序的下一个元素
     * @return
     */
    Object next();

    /**
     * 判断是否还有下一个元素
     * @return
     */
    Boolean hasNext();
}

/**
 * 通用接口用于获取迭代器对象
 */
public interface Container {

    /**
     * 获取迭代器对象
     * @return
     */
    Iterator getIterator();
}

第二步:创建实现了 Container 接口的实体类。该类有实现了 Iterator 接口的内部类 NameIterator

/**
 * @ClassName NameRepository
 * @Description 包含一组name的数据集
 * @Date 2019/6/29 14:40
 * @Version 1.0
 **/
public class NameRepository implements Container {

    public List<String> names = null;

    public NameRepository(List<String> names) {
        this.names = names;
    }

    @Override
    public Iterator getIterator() {
        return new NameIterator();
    }

    /**
     * 使用内部类的方式
     */
    private class NameIterator implements Iterator {

        int index;

        @Override
        public Object first() {
            return names.get(0);
        }

        @Override
        public Object last() {
            return names.get(names.size() - 1);
        }

        @Override
        public Object next() {
            if (this.hasNext()) {
                return names.get(index++);
            }
            return null;
        }

        @Override
        public Boolean hasNext() {
            if (index < names.size()) {
                return true;
            }
            return false;
        }
    }
}

第三步:创建客户端测试功能

/**
 * @ClassName IteratorDemo
 * @Description 迭代器客户端测试
 * @Date 2019/6/29 14:47
 * @Version 1.0
 **/
public class IteratorDemo {

    public static void main(String[] args) {
        List<String> names = new ArrayList<>();
        names.add("zhangsan_1");
        names.add("zhangsan_2");
        names.add("zhangsan_3");
        names.add("zhangsan_4");
        names.add("zhangsan_5");
        names.add("zhangsan_6");
        names.add("zhangsan_7");

        NameRepository nameRepository = new NameRepository(names);
        Iterator iterator = nameRepository.getIterator();
        while (iterator.hasNext()) {
            System.out.println(iterator.next());
        }

        System.out.println("------------------------------");
        System.out.println("集合的第一个元素:" + iterator.first());
        System.out.println("集合的最后一个元素:" + iterator.last());
    }
}

5、迭代器模式总结

  • 迭代器模式分离了集合对象的遍历行为,抽象出一个迭代器类来负责,这样既可以做到不暴露集合内部的数据结构,又可让外部代码透明地访问集合内部的元素
  • 迭代器模式非常常用,各种高级语言都对他进行了封装
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值