本文實例講述了Python設計模式之迭代器模式原理與用法。分享給大家供大家參考,具體如下:
迭代器模式(Iterator Pattern):提供方法順序訪問一個聚合對象中各元素,而又不暴露該對象的內(nèi)部表示.
下面是一個迭代器模式的demo:
#!/usr/bin/env python# -*- coding:utf-8 -*-__author__ = 'Andy'"""大話設計模式設計模式——迭代器模式迭代器模式(Iterator Pattern):提供方法順序訪問一個聚合對象中各元素,而又不暴露該對象的內(nèi)部表示."""#迭代器抽象類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()運行結果:

上面類的設計如下圖:

當需要對聚集有多種方式遍歷時,可以考慮使用迭代器模式
迭代器模式分離了集合的遍歷行為,抽象出一個迭代器類來負責,這樣既可以做到不暴露集合內(nèi)部結構,又可以讓外部代碼透明的訪問集合內(nèi)部的數(shù)據(jù)
更多關于Python相關內(nèi)容可查看本站專題:《Python數(shù)據(jù)結構與算法教程》、《Python Socket編程技巧總結》、《Python函數(shù)使用技巧總結》、《Python字符串操作技巧匯總》及《Python入門與進階經(jīng)典教程》
新聞熱點
疑難解答