国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python設計模式之迭代器模式原理與用法實例分析

2020-02-16 00:34:05
字體:
供稿:網(wǎng)友

本文實例講述了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)典教程》

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 陆丰市| 郯城县| 昌黎县| 涿州市| 香港| 冷水江市| 扎囊县| 广丰县| 阿坝| 土默特右旗| 屏东市| 丰宁| 崇州市| 从江县| 博乐市| 天全县| 永平县| 蒙城县| 华亭县| 平昌县| 德庆县| 扎囊县| 山阳县| 定兴县| 沽源县| 高安市| 都昌县| 灵丘县| 伊春市| 嘉善县| 太原市| 镇康县| 石柱| 来凤县| 余姚市| 沁阳市| 江达县| 定西市| 宜君县| 白朗县| 武冈市|