iOS开发-迭代器模式
迭代器模式(Iterator),提供一种方法顺序访问一个聚合对象中的各种元素,而又不暴露该对象的内部表示。开发过程中,我们可能需要针对不同的需求,可能需要以不同的方式来遍历整个整合对象,但是我们不希望遍历的对象内部存储结构被外部知道,那么可以将对象包装成一个迭代器,迭代器中定义中遍历对象的方法下一个,是否存在下一个对象,删除等遍历需要的统一接口,迭代器在Java和.NET使用的比较多,自定义实现叶非常简单,可以简单的看一下迭代器模式的UML类图。

迭代器定义基本的遍历操作方法,容器定义公共的创建迭代器的方法,子类负责实现具体需要引用的迭代器,我们可以假设图书馆是一个抽象容器,图书馆下面分为国家图书馆和个人图书馆,个人图书馆存储书籍的方式是可变数组存储书籍,国家图书馆数据存储书籍,分别创建不同的迭代器;
BookLibrary容器接口:
@protocol BoolLibraryProtocol<NSObject> @optional
-(Iterator *)createIterator; @end @interface BookLibrary : NSObject<BoolLibraryProtocol> @end
CountryBookLibrary国家图书馆:
@interface CountryBookLibrary() @property (strong,nonatomic) NSArray *bookArr; @end @implementation CountryBookLibrary - (instancetype)init
{
self = [super init];
if (self) {
Book *one=[self addBook:@"CountryBookLibrary" price:10];
Book *next=[self addBook:@"博客园-FlyElephant" price:20];
self.bookArr=@[one,next];
}
return self;
} -(Iterator *)createIterator{
return [[CountryIterator alloc]initWithData:self.bookArr];
} -(Book *)addBook:(NSString *)bookName price:(float)price{
Book *book=[[Book alloc]init];
book.bookName=bookName;
book.price=price;
return book;
} @end
PersonLibraryBook个人图书馆:
@interface PersonBookLibray() @property (strong,nonatomic) NSMutableArray *books; @end @implementation PersonBookLibray - (instancetype)init
{
self = [super init];
if (self) {
[self addBook:@"PersonIterator" price:100];
[self addBook:@"博客园-FlyElephant" price:200];
}
return self;
} -(Iterator *)createIterator{
return [[PersonIterator alloc]initWithData:self.books];
} -(void)addBook:(NSString *)bookName price:(float)price{
Book *book=[[Book alloc]init];
book.bookName=bookName;
book.price=price;
[self.books addObject:book];
} #pragma mark - getter and setter
-(NSMutableArray *)books{
if (!_books) {
_books=[[NSMutableArray alloc]init];
}
return _books;
} @end
迭代器Iterator:
@protocol IteratorProtocol <NSObject> @optional
-(Boolean)hasNext; @optional
-(id)next; @end @interface Iterator : NSObject<IteratorProtocol> @end
国家图书馆引用的迭代器:
@interface CountryIterator() @property (strong,nonatomic) NSArray *arr;
@property (assign,nonatomic) NSInteger position; @end @implementation CountryIterator -(instancetype)initWithData:(NSArray *)data{
self=[super init];
if (self) {
self.arr=data;
}
return self;
} -(Boolean)hasNext{
if (self.position>=[self.arr count]||!self.arr[self.position]) {
return false;
}else{
return true;
}
} -(id)next{
Book *book=self.arr[self.position];
self.position+=1;
return book;
} @end
个人图书馆引用的迭代器:
@interface PersonIterator() @property (assign,nonatomic) NSInteger position;
@property (strong,nonatomic) NSMutableArray *mutableArr; @end @implementation PersonIterator -(instancetype)initWithData:(NSMutableArray *)data{
self=[super init];
if (self) {
self.mutableArr=data;
}
return self;
} -(Boolean)hasNext{
if (self.position>=[self.mutableArr count]||![self.mutableArr objectAtIndex:self.position]) {
return false;
}else{
return true;
}
} -(id)next{
Book *book=[self.mutableArr objectAtIndex:self.position];
self.position+=1;
return book;
} @end
实际调用:
-(void)iteratorDesign{
BookLibrary *personLibrary=[[PersonBookLibray alloc]init];
Iterator *personIterator=[personLibrary createIterator];
[self logLibraryInfo:personIterator];
BookLibrary *countryLibrary=[[CountryBookLibrary alloc]init];
Iterator *countryIterator=[countryLibrary createIterator];
[self logLibraryInfo:countryIterator];
}
-(void)logLibraryInfo:(Iterator *)iterator{
while ([iterator hasNext]) {
Book *book=[iterator next];
NSLog(@"书名:%@--价格:%ld",book.bookName,book.price);
}
}
测试结果:

迭代器模式的优点:支持以不同的方式遍历一个聚合对象(不同的聚合对象不同的遍历方式),迭代器简化了聚合类(统一接口),在迭代器模式中,增加新的聚合类和迭代器类都很方便,无须修改原有代码(假设新增字典迭代器,直接添加就行,符合对扩展开放,对修改关闭的原则0)
缺点: 迭代器模式将存储数据和遍历数据的职责分离,增加新的聚合类需要对应增加新的迭代器类,类的个数成对增加,这在一定程度上增加了系统的复杂性。不过集合类型总共就几种,基本上系统使用没有问题,个人使用的需注意一下;
iOS开发-迭代器模式的更多相关文章
- iOS开发-代理模式
代理模式有的时候也被称之为委托模式,但是实际上两者是有分别的,代理模式为另一个对象提供一个替身或占位符访问这个对象,代理对象和控制访问对象属于同一类,委托对象和对象不一定属于同一类.两者都可以控制类的 ...
- iOS开发-命令模式
命令模式算是设计模式中比较简单的,最常见的例子是工作任务安排下来进行编程,如果工作任务不需要完成,我们可以取消我们之前完成的代码,也可以理解为回滚撤销操作.这里面涉及到命令模式中的两个对象,一个是动作 ...
- iOS开发-工厂模式
工厂模式算是开发中比较常见的设计模式,简单工厂模式,工厂模式和抽象工厂模式,都属于工厂模式.简单工厂模式(simple factory)是类的创建模式,静态工厂方法(static factory me ...
- iOS开发-状态模式
状态模式允许对象内部状态改变时改变它的行为,对象看起来好像修改了它的类.状态模式看起来和策略模式比较相像,策略模式是将可以互换的行为封装起来,然后通过使用委托的方式,决定使用哪一个行为,状态也是封装行 ...
- iOS开发——工厂模式
工厂模式很好用,为表诚意,我直接搞个实用的例子放这,解析一个订单的数据,并且这个订单里面可能不止一件商品的做法. 还是直接上代码,不懂的地方,再提出来. 1.在MyOrderDeals.h文件中 #i ...
- iOS开发-模板方法模式
模板方法模式定义一个操作中的算法的骨架,而将步骤延迟到子类中.模板方法使得子类可以不改变一个算法的结构即可重定义算法的某些特定步骤.模板方法模式是由子类决定实现算法中的步骤,工厂方法由子类决定实现哪一 ...
- iOS开发-策略模式
策略(Strategy)模式定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换.策略模式让算法独立于使用它的客户而独立变化.策略模式是对算法的包装,是把使用算法的责任和算法本身分割开 ...
- iOS开发——swift精讲&MVC应用实战
MVC应用实战 iOS开发中设计模式是很重要的,其中,使用最多的就是MVC模式,今天就简单介绍一下在Swift中这么使用MVC模式来实现我们想要的功能: 模型-视图-控制器(Model-View-Co ...
- 通知模式实现两个textField传值及模态视图——iOS开发
通知模式实现两个textField传值及模态视图--iOS开发 利用通知模式,实现两个不同界面的textField之间的传值,在界面二输入字符,传值到前一界面的textField. 界面的切换,这里临 ...
随机推荐
- (十) 一起学 Unix 环境高级编程 (APUE) 之 线程控制
. . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...
- Ubuntu 针对 SSD 的优化方案
. . . . . 首先看下 LZ 的分区情况: >$ sudo fdisk -l Disk /dev/sda: bytes heads, sectors/track, cylinders, t ...
- MATLAB - 运算符
1.关系运算符用来比较两个数之间的大小关系,在Matlab中的关系运算符包括: < 小于 <= 小于或等于 > 大于 >= 大于或等于 == ...
- 使用Aspose插件将程序中的表格,导出生成excel表格
http://www.cnblogs.com/lanyue52011/p/3372452.html这个是原文地址 /// <summary> /// 点击按钮,将内存表导出excel表格! ...
- java多线程学习-开篇
1.Java线程基本概念 在操作系统中两个比较容易混淆的概念是进程(process)和线程(thread).操作系统中的进程是资源的组织单位.进程有一个包含了程序内容和数据的地址空间,以及其它的资源, ...
- 第一章 JacksonUtil 序列化与反序列化属性总结
1.json-lib与Jackson 关于json-lib与Jackson对比总结如下: 1).性能方面,Jackson的处理能力高出Json-lib10倍左右. 2).json-lib已经停止更新, ...
- 统计学习方法笔记(KNN)
k近邻法(k-nearest neighbor,k-NN) 输入:实例的特征向量,对应于特征空间的点:输出:实例的类别,可以取多类. 分类时,根据其k个最近邻的训练实例的类别,通过多数表决等方式进行预 ...
- [MOSEK] Mosek求解中遇到的奇葩内存问题
在使用mosek优化库的时候,使用http://docs.mosek.com/7.0/capi/MSK_getxx_.html的 MSKrescodee MSK_getxx ( MSKtask_t t ...
- JS 获取服务器时间
function getSevertime(){ var xmlHttp = new XMLHttpRequest(); xmlHttp.open("get",location.h ...
- Spring的定时任务配置(转)
spring的定时任务配置分为三个步骤: 1.定义任务 2.任务执行策略配置 3.启动任务 1.定义任务 <!--要定时执行的方法--> <bean id="testTas ...