《GOF设计模式》学习笔记—Iterator迭代器

本文介绍迭代器模式,探讨其在简化聚合类型接口、提供多种迭代算法及支持多遍历方面的价值。并以Java集合类为例,说明迭代器模式的实际应用。

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

 
官方描述
提供一种方法顺序访问一个聚合对象中的各元素,而又无需暴露该聚合对象的内部表示。
 
我的理解
1、价值所在:
Iterator迭代器模式相对于其他模式显得对于要处理的问题更具体一些,它把一个聚合对象中元素访问和遍历操作从该聚合对象内部分离出去,从而提供了以下三方面的好处:
1)简化聚合类型接口
因为聚合对象不再需要直接对外提供访问和遍历自己内部元素的服务,所以简化了聚合对象类型的接口;
2)便于提供多种类型的迭代算法
我们可以很方便地通过提供多种迭代器,以对聚合对象进行不同形式的访问和遍历,而这种扩展对聚合对象本身不产生影响;
3)可以对聚合对象同时进行多个遍历
对于一个聚合对象,我们可以创建多个迭代器与其关联,这样我们就可以同时对该聚合对象进行多个遍历操作;
 
2、迭代器与聚合类的关系
由于迭代器是将本属于聚合对象的元素访问和遍历操作从聚合对象中分离,并进行独立的包装,所以迭代器和聚合对象本身是密切关联的。
迭代器在创建的时候,至少在被使用之前,必须知道它要访问的具体聚合对象,并且由于不同类型的聚合对象需要的迭代器也往往不同,所以让聚合对象创建相关联的迭代器就显得非常的自然和合情合理,通过Factory Method可以很好的实现这一点。
 
3、实际应用
在Java中,容器类Collection的实现即采用了Iterator模式,对于各种具体的Collection子类,如ArrayList、LinkedList、HashSet等,都具体实现了相应的Iterator子类,并通过Factory Method模式将集合类和对应的迭代器类相关联,这样既简化了集合类的设计,又便于用户使用和扩展。JDK中的集合类/迭代器类部分结构图如下:
 
 
4、备注
1)Iterator模式的结构图
 
 
2)Iterator模式参与者描述
 
1、Iterator(迭代器)
——迭代器定义访问和遍历元素的接口。
2、ConcreteIteratro(具体迭代器)
——具体迭代器实现迭代器的接口;
——对该聚合遍历时跟踪当前位置;
3、Aggregate(聚合)
——聚合定义创建相应迭代器对象的接口;
4、ConcreteAggregae(具体聚合类)
——具体聚合实现创建相应迭代器的接口,该操作返回ConcreteIterator的一个适当的实例
 
5、参考资料
       GOF《设计模式——可复用面向对象软件的基础》
 
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值