前言
迭代器模式其实在我们平时开发中,经常会用到,但是我们并不会自己去写一个迭代器,通常是调用java自带的迭代器,只有在自己想要设计一种新的数据结构的时候,可能会创建对应的迭代器,即便如此,我们也要了解迭代器是怎么实现的,它解决了什么问题,好奇心驱使我去学习了一下。
解决的问题:
为了解决在平时开发中,经常要访问一个聚合对象中的各个元素,如“数据结构”中的链表遍历,通常的做法是将链表的创建和遍历都放在同一个类中,但这种方式不利于程序的扩展,如果要更换遍历方法就必须修改程序源代码,这违背了 “开闭原则”的问题。
定义
提供一个对象来顺序访问聚合对象中的一系列数据,而不暴露聚合对象的内部表示。迭代器模式是一种对象行为型模式
结构
迭代器模式主要包含以下角色:
- 抽象聚合(Aggregate)角色:定义存储、添加、删除聚合对象以及创建迭代器对象的接口。
- 具体聚合(ConcreteAggregate)角色:实现抽象聚合类,返回一个具体迭代器的实例。
- 抽象迭代器(Iterator)角色:定义访问和遍历聚合元素的接口,通常包含 hasNext()、first()、next() 等方法。
- 具体迭代器(Concretelterator)角色:实现抽象迭代器接口中所定义的方法,完成对聚合对象的遍历,记录遍历的当前位置。
特点
优点:
- 访问一个聚合对象的内容而无须暴露它的内部表示。
- 遍历任务交由迭代器完成,这简化了聚合类。
- 它支持以不同方式遍历一个聚合,甚至可以自定义迭代器的子类以支持新的遍历。
- 增加新的聚合类和迭代器类都很方便,无须修改原有代码。
- 封装性良好,为遍历不同的聚合结构提供一个统一的接口。
缺点:
- 增加了类的个数,一定程度上增加了程序的复杂度
案例
1 | package xyz.molzhao; |
1 | package xyz.molzhao.standard; |
1 | package xyz.molzhao; |
1 | package xyz.molzhao.impl; |
1 | package xyz.molzhao; |
案例地址
欢迎大家访问我的Github地址,如果喜欢的话,希望能给个Star,点击此处获取本案例源码
该文章参考的原文链接 http://c.biancheng.net/view/1395.html
如果有小伙伴,想要一起交流学习的,欢迎添加博主微信。