微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Python设计模式之迭代器模式原理与用法实例分析

这篇文章主要介绍了Python设计模式之迭代器模式原理与用法,结合具体实例形式分析了迭代器模式的概念、原理、定义及使用方法,代码注释说明简单易懂,需要的朋友可以参考下

本文实例讲述了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) 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

运行结果:

上面类的设计如下图:

当需要对聚集有多种方式遍历时,可以考虑使用迭代器模式

迭代器模式分离了集合的遍历行为,抽象出一个迭代器类来负责,这样既可以做到不暴露集合内部结构,又可以让外部代码透明的访问集合内部的数据

更多关于Python相关内容可查看本站专题:《Python数据结构与算法教程》、《Python Socket编程技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐