Python设计模式之迭代器模式原理与用法实例分析
2019-01-11 12:02
1276 查看
本文实例讲述了Python设计模式之迭代器模式原理与用法。分享给大家供大家参考,具体如下:
迭代器模式(Iterator Pattern):提供方法顺序访问一个聚合对象中各元素,而又不暴露该对象的内部表示.
下面是一个迭代器模式的demo:
#!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'Andy' """ 大话设计模式 设计模式――迭代器模式 迭代器模式(Iterator Pattern):提供方法顺序访问一个聚合对象中各元素,而又不暴露该对象的内部表示. """ #迭代器抽象类 class Iterator(object): def First(self): pass def Next(self): pass def Isdone(self): pass def CurrItem(self): pass #聚集抽象类 class Aggregate(object): def CreateIterator(self): pass #具体迭代器类 class ConcreteIterator(Iterator): def __init__(self, aggregate): self.aggregate = aggregate self.curr = 0 def First(self): return self.aggregate[0] def Next(self): ret = None self.curr += 1 if self.curr < len(self.aggregate): ret = self.aggregate[self.curr] return ret def Isdone(self): return True if self.curr+1 >= len(self.aggregate) else False def CurrItem(self): return self.aggregate[self.curr] #具体聚集类 class ConcreteAggregate(Aggregate): def __init__(self): self.ilist = [] def CreateIterator(self): return ConcreteIterator(self) class ConcreteIteratorDesc(Iterator): def __init__(self, aggregate): self.aggregate = aggregate self.curr = len(aggregate)-1 def First(self): return self.aggregate[-1] def Next(self): ret = None self.curr -= 1 if self.curr >= 0: ret = self.aggregate[self.curr] return ret def Isdone(self): return True if self.curr-1<0 else False def CurrItem(self): return self.aggregate[self.curr] if __name__=="__main__": ca = ConcreteAggregate() ca.ilist.append("大鸟") ca.ilist.append("小菜") ca.ilist.append("老外") ca.ilist.append("小偷") itor = ConcreteIterator(ca.ilist) print itor.First() while not itor.Isdone(): print itor.Next() print "――――倒序――――" itordesc = ConcreteIteratorDesc(ca.ilist) print itordesc.First() while not itordesc.Isdone(): print itordesc.Next()
运行结果:
上面类的设计如下图:
当需要对聚集有多种方式遍历时,可以考虑使用迭代器模式
迭代器模式分离了集合的遍历行为,抽象出一个迭代器类来负责,这样既可以做到不暴露集合内部结构,又可以让外部代码透明的访问集合内部的数据
更多关于Python相关内容可查看本站专题:《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- Python设计模式之解释器模式原理与用法实例分析
- JavaScript设计模式之单例模式原理与用法实例分析
- Python多进程与服务器并发原理及用法实例分析
- Python实现希尔排序算法的原理与用法实例分析
- Python实现的插入排序算法原理与用法实例分析
- Java设计模式之策略模式原理与用法实例详解
- PHP设计模式之原型设计模式原理与用法分析
- Python实现的堆排序算法原理与用法实例分析
- Java设计模式之装饰模式原理与用法实例详解
- Python实现的选择排序算法原理与用法实例分析
- Python实现的基数排序算法原理与用法实例分析
- Python自定义装饰器原理与用法实例分析
- Python装饰器原理与简单用法实例分析
- Java 23种设计模式详尽分析与实例解析之二--结构型模式
- python抽象基类用法实例分析
- 设计模式综合实例分析之数据库同步系统(一)
- python中lambda与def用法对比实例分析
- Python实现程序的单一实例用法分析
- python中getaddrinfo()基本用法实例分析
- Python中的对象,方法,类,实例,函数用法分析