【行为型】Iterator模式
迭代器模式提供一种方法顺序访问聚合对象中的各个元素,而又不需要暴露该聚合对象的内部表示。对于该模式,估计几乎所有的人都使用过,在此直接给出类结构图参考如下:

如前所述,迭代器模式的思想主要是:一能提供顺序访问各个元素且不需要暴露内部细节;二是要能够访问具体 元素。从而达到简化聚合对象的接口的目的 。因此,Iterator所提供的接口需要包括对列表的遍历操作以及对元素的访问操作。如上图所提供的是列表的遍历操作,其实还应该提供元素的访问操作,如:operator->()与operator.(),或者get()操作。关于该模式的另外一个需要考虑的问题是通用性。如果说仅仅只是为某一列表的遍历设计专门的迭代器,则没有可复用性,那么其他不同的列表就需要分别设计各种对应的迭代器。STL中的所有数据结构的设计都是通用的,其中就包括迭代器。其主要是通过模板元编程思想来实现,具体实现细节也是较为复杂的,贯穿它们的有一个非常重要的概念:类型粹取器,首先要先理解它。具体细节有兴趣的自行找书研究一下。
【行为型】Iterator模式的更多相关文章
- 1、迭代器 Iterator模式 一个一个遍历 行为型设计模式
		
1.Iterator模式 迭代器(iterator)有时又称游标(cursor)是程序设计的软件设计模式,可在容器(container,例如链表或者阵列)上遍访的接口,设计人员无需关心容器的内容. I ...
 - 第3月第13天 cpp模版 Iterator模式 proactor
		
1.模版除了传参,还可以自动创建.而传指针只是传参而已. template <class TYPE, class FUNCTOR, class ACE_LOCK, typename TIME_P ...
 - Java 实现迭代器(Iterator)模式
		
类图 /** * 自己定义集合接口, 相似java.util.Collection * 用于数据存储 * @author stone * */ public interface ICollection ...
 - 设计模式之Iterator模式
		
STL里的iterator就是应用了iterator模式. 一.什么是迭代模式 Iterator模式也叫迭代模式,是行为模式之一,它把对容器中包含的内部对象的访问委让给外部类,使用Iterator按顺 ...
 - Java设计模式(12)迭代模式(Iterator模式)
		
上了这么多年学,我发现一个问题,好象老师都很喜欢点名,甚至点名都成了某些老师的嗜好,一日不点名,就饭吃不香,觉睡不好似的,我就觉得很奇怪,你的课要是讲的好,同学又怎么会不来听课呢,殊不知:“误人子弟, ...
 - 设计模式—迭代器Iterator模式
		
什么是迭代器模式? 让用户通过特定的接口访问容器的数据,不需要了解容器内部的数据结构. 首先我们先模仿集合中ArrayList和LinkedList的实现.一个是基于数组的实现.一个是基于链表的实现, ...
 - 设计模式(一)Iterator模式
		
Iterator模式用于在数据集合中按照顺序遍历集合.即迭代器模式. 下面来看一段实现了迭代器模式的示例程序. 这段程序的作用是将书(Book)放置到书架(BookShelf)中,并将书的名字按顺序显 ...
 - 设计模式C++描述----20.迭代器(Iterator)模式
		
一. 举例说明 我们知道,在 STL 里提供 Iterator 来遍历 Vector 或者 List 数据结构. Iterator 模式也正是用来解决对一个聚合对象的遍历问题,将对聚合的遍历封装到一个 ...
 - 【设计模式大法】Iterator模式
		
Iterator模式 --一个一个遍历 在Java中的for语句中 i++的作用是让 i 的值在每次循环后自增1,这样就可以访问数组中的下一个元素.下下一个元素.再下下一个元素,也就实现了从头至尾逐一 ...
 - Java设计模式之Iterator模式
		
分类: [java]2013-07-15 10:58 917人阅读 评论(0) 收藏 举报 所谓Iterator模式,即是Iterator为不同的容器提供一个统一的访问方式.本文以java中的容器为例 ...
 
随机推荐
- Combination Sum —— LeetCode
			
Given a set of candidate numbers (C) and a target number (T), find all unique combinations in C wher ...
 - UVa11248 Frequency Hopping(最大流+最小割)
			
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=33206 [思路] 最大流最小割. 可以确定的是如果不可行需要修改的 ...
 - freemarker使用map
			
freemaker强大的地方是还可以使用map. 一个场景就是对应后端的type类型, type=01,02,03,04, 我们可以在controller定义一个map typeMap,好处就 ...
 - Jenkins 一: 环境安装以及配置
			
安装JDK 下载地址: http://www.oracle.com/technetwork/java/javase/downloads/index.html 选择的JDK版本和开发使用的JDK版本最好 ...
 - poj1013
			
题目大意:假造的银币 Sally Jones有一些游客给的银币,但是只有11枚是真正的银币(有一枚是假的),从颜色和大小是无法区分真比还是假币的,但是它的重量和真币是不同的,Sally Jones它是 ...
 - Qt Quick 事件处理之信号与槽
			
前面两篇文章<QML 语言基础>和<Qt Quick 简单教程>中我们介绍了 QML 语言的基本的语法和 Qt Quick 的常见元素,亲们,通过这两篇文章,您应该已经能够完毕 ...
 - searchbar的使用介绍
			
searchBar的使用介绍 首先如何创建一个SearchBar实例: self.searchBar = [[UISearchBar alloc] initWithFrame: CGRectMake( ...
 - 解密-神秘的 RunLoop
			
引言 一直以来RunLoop就是个神秘的领域,好多2.3年的开发者都不能准确的表述它的作用,说它神秘,其实RunLoop并没有大家想象中的那么神秘,那么不好理解,本文就带大家好好剖析一下”神秘的Run ...
 - Android之发送短信的两种方式
			
SMS涉及的主要类SmsManager 实现SMS主要用到SmsManager类,该类继承自java.lang.Object类,下面我们介绍一下该类的主要成员. 公有方法: ArrayList< ...
 - 从C到汇编:栈是计算机工作的基础
			
作者:r1ce 原创作品转载请注明出处 <Linux内核分析> MOOC课程http://mooc.study.163.com/course/U ...