python设计模式(十七):迭代器模式——迭代器与生成器
迭代模式:对外提供一个接口,实现顺序访问聚合数据,但是不显示该数据的内部机制。这就是Python中大名鼎鼎的迭代器。
实现迭代模式对于Python来说没有多余的代码,寥寥几行代码足可以实现迭代模式。
示例code:
# -*- coding:utf-8 -*-
def FibonacciSequence(n):
x = 0
y = 1
i = 1
while True:
yield y
if i == n:
break
x, y = y, x+y
i += 1
if __name__ == '__main__':
test = FibonacciSequence(7)
next(test)
1
next(test)
1
next(test)
2
next(test)
3
next(test)
5
next(test)
8
next(test)
13
next(test)
以上是使用迭代模式输出斐波那契数列的前n列,较传统的实现方法而言更加的简洁。
迭代器模式常应用场景是在只提供接口而不暴露内部机制的场景中,yield关键词在python协程中也有应用。
迭代器、生成器、可迭代对象概念
生成器:对于一个数据集合,生成器并不记住每个元素值,但在循环中记录元素位置并根据元素生成规则推算出数值,这种边循环边计算的形式是生成器。
迭代器:是一种访问集合的方式,记住遍历位置,从第一个元素开始访问,直到最后一个元素,并且只能前进不能后退。
可迭代对象:像list、set、str这种可以通过for遍历的类型是可迭代对象,这种遍历顺序可以从尾到头。
凡是通过next()访问的对象都是迭代器类型,也就是说生成器就是迭代器的一种;凡是可以通过for遍历的都是可迭代对象,可迭代对象可以通过iter()转化为迭代器。
生成器中有几个关键词:yield、yield form、send、next()、__next__()具体作用见示例代码。
# 生成器示例
def test():
a = 1
while True:
b = yield a
a += b
def test1():
yield from test() # yield form 是创建一个嵌套的生成器,form后面跟一个生成器,每次执行到yield form后会先把内层的生成器执行完。
if __name__ == '__main__':
fn = test()
next(fn) # 通过next访问内部元素
fn.__next__() # 通过__next__()方法访问内部元素,作用同上
fn.send(4) # send有next的作用,同时向生成器内部的yield左边等式赋值
fn1 = test1()
fn.__next__()
迭代器和可迭代对象有几个关键词:next()、itre()、for
# 迭代器及可迭代对象
a = (i for i in range(50))
b = [1, 2, 3, 4, 5, 6]
if __name__ == '__main__':
next(a)
c = iter(b)
next(c)
其中奥秘可能得亲身恭行,才能探知,这里只做抛砖引玉。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Python装饰器abstractmethod、property、classmethod、staticmethod及自定义装饰器
总览: @abstractmethod:抽象方法,含abstractmethod方法的类不能实例化,继承了含abstractmethod方法的子类必须复写所有abstractmethod装饰的方法,未被装饰的可以不重写 @ property:方法伪装属性,方法返回值及属性值,被装饰方法不能有参数,必须实例化后调用,类不能调用 @ classmethod:类方法,可以通过实例对象和类对象调用,被该函数修饰的方法第一个参数代表类本身常用cls,被修饰函数内可调用类属性,不能调用实例属性 @staticmethod:静态方法,可以通过实例对象和类对象调用,被装饰函数可无参数,被装饰函数内部通过类名.属性引用类属性或类方法,不能引用实例属性 案例讲解: @abstractmethod 用于程序接口的控制,正如上面的特性,含有@abstractmethod修饰的父类不能实例化,但是继承的子类必须实现@abstractmethod装饰的方法 #-*-coding:utf-8-*- fromabcimportABC,abstractmethodclassA(ABC): @abstractmetho...
- 下一篇
python设计模式(十八):中介者模式
将其他对象之间的交互装在中介者对象中,达到松耦合、隐式引用、独立变化,与代理模式有相似之感《python设计模式(十一):代理模式模式》,但是代理模式是结构性模式,侧重于对对象调用的接口控制,而中介者模式是行为性模式,解决对象与对象之间相互调用的行为问题。 我们以生产者和消费者之间的销售作为一个中介者,用对象来表示生产和购买及流通这个过程。 classConsumer: """消费者类""" def__init__(self,product,price): self.name="消费者" self.product=product self.price=price defshopping(self,name): """买东西""" print("向{}购买{}价格内的{}产品".format(name,self.price,self.product))classProducer: """生产者类""" def__init__(self,product,price): self.name="生产者" self.product=product self.price=price defsale...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS8编译安装MySQL8.0.19
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS7,CentOS8安装Elasticsearch6.8.6
- CentOS6,CentOS7官方镜像安装Oracle11G
- Windows10,CentOS7,CentOS8安装Nodejs环境
- Red5直播服务器,属于Java语言的直播服务器
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7