Python3中的迭代器

  迭代器模式主要是访问集合元素的一中方式,迭代器不会把整个集合对象加载到内存,而是按照顺序将集合中的元素一个一个的进行迭代,这样每次迭代的时候只取少量的元素,比较省内存

  注:

    1.只能按照顺序一个一个的通过__next__()访问下一个元素,不能随机访问

    2.只能从头访问到尾,不能访问到中间元素的时候,在去访问前面的元素

    3.Python3中访问下一个元素可以使用标准的函数next(iter)了

    4.如果已经迭代完全部元素,再次调用next(item)则引发异常StopIteration

# 使用iter()构造方法创建一个迭代器
it = iter([1, 2, 3, 4, 5, ])
print(next(it)) # 输出结果 1
print(next(it)) # 输出结果 2
print(next(it)) # 输出结果 3
print(next(it)) # 输出结果 4
print(next(it)) # 输出结果 5
print(next(it)) # 输出结果 引发异常:StopIteration

1.使用构造函数创建迭代器

# Python内置的 for...in语法访问集合就是使用的迭代的方式
with open("readme.txt", encoding="utf-8") as log_file:
for line in log_file:
print(line)

2.使用for...in迭代会自动结束,不会出现异常

Python3中的生成器

  如果一个函数中出现了yield语句,那么这个函数将不再是普通的函数,它将变成生成器函数,生成器函数返回的是一个迭代器,这个函数可以被yield中断,并记录中断的状态,下次还可以继续执行,可以理解为迭代的开始就是函数的开始,迭代的结束就是函数的结束,生成器是比较快捷的创建一个迭代器的方式

# 生成器函数,为了便于理解这里没有用循环
def generator_func(count):
yield_value = "yield_value的默认值"
print("--------第1个yield之前的代码------------")
print("yield的值:", yield_value)
print("count的值:", count)
count += 1
yield_value = yield count
print("--------第2个yield之前的代码------------")
print("yield的值:", yield_value)
print("count的值:", count)
count += 1
yield_value = yield count
print("--------第3个yield之前的代码------------")
print("yield的值:", yield_value)
print("count的值:", count)
count += 1
yield_value = yield count
print("--------第3个yield之后的代码------------")
print("yield的值:", yield_value)
print("count的值:", count) # 调用生成器函数,返回了一个迭代器对象 gtr
gtr = generator_func(0) # 虽然类型显示 generator(生成器的意思) 但它是个迭代器
# 可以说生成器就是迭代器,返回这种迭代器的函数叫生成器函数
print(type(gtr)) # 我们可以调用 next(gtr) 或 gtr.send(obj) 来执行上一个yield之后的代码
# 没有上一个yield,就执行第一个yield之前的代码
# next(gtr)和gtr.send(obj)的唯一不同是:
# gtr.send(obj)会把上一个yield赋值为obj
# 所以如果第一次迭代使用的是gtr.send(obj)方法
# 那一定要这么写: gtr.send(None),因为在这之前并没有上一个yield
# 而且,gtr.send(obj) + next(gtr)有效执行次数(不报错)之和等于最大迭代次数
# 另外,如果yield之后有个对象,那么在执行next(gtr)或gtr.send(obj)时,会将其返回
# 最后,Python3中的 next(gtr) 等价于 gtr.__next__()
gtr.send(None)
next(gtr)
next(gtr)

生成器代码解析

Python3-设计模式-迭代器模式的更多相关文章

  1. 19. 星际争霸之php设计模式--迭代器模式

    题记==============================================================================本php设计模式专辑来源于博客(jymo ...

  2. java设计模式——迭代器模式

    一. 定义与类型 定义:提供一种方法,顺序访问一个集合对象中的各个元素,而又不暴露该对象的内部表示 类型:行为型. 二. 使用场景 (1) 访问一个集合对象的内容而无需暴露它的内部表示 (2)  为遍 ...

  3. [Head First设计模式]生活中学设计模式——迭代器模式

    系列文章 [Head First设计模式]山西面馆中的设计模式——装饰者模式 [Head First设计模式]山西面馆中的设计模式——观察者模式 [Head First设计模式]山西面馆中的设计模式— ...

  4. JAVA 设计模式 迭代器模式

    用途 迭代器模式 (Iterator) 提供一种方法顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部表示. 迭代器模式是一种行为型模式. 结构

  5. 深入浅出设计模式——迭代器模式(Iterator Pattern)

    模式动机 一个聚合对象,如一个列表(List)或者一个集合(Set),应该提供一种方法来让别人可以访问它的元素,而又不需要暴露它的内部结构.针对不同的需要,可能还要以不同的方式遍历整个聚合对象,但是我 ...

  6. JavaScript设计模式 - 迭代器模式

    迭代器模式是指提供一种方法顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示. 迭代器模式可以把迭代的过程从业务逻辑中分离出来,在使用迭代器模式之后,即使不关心对象的内部构造,也可以按顺 ...

  7. javascript设计模式-迭代器模式(Iterator)

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. 设计模式 --迭代器模式(Iterator)

    能够游走于聚合内的每一个元素,同时还可以提供多种不同的遍历方式.   基本概念: 就是提供一种方法顺序访问一个聚合对象中的各个元素,而不是暴露其内部的表示.   使用迭代器模式的优点: 遍历集合或者数 ...

  9. js设计模式--迭代器模式

    迭代器模式: 迭代器模式提供一种方法顺序访问一个聚合对象中各个元素,而又不需要暴露该方法中的内部表示.js中我们经常会封装一个each函数用来实现迭代器. 理解的意思:提供一个方法,去把对象的每一项按 ...

  10. javascript设计模式——迭代器模式

    前面的话 迭代器模式是指提供一种方法顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示.迭代器模式可以把迭代的过程从业务逻辑中分离出来,在使用迭代器模式之后,即使不关心对象的内部构造,也 ...

随机推荐

  1. 使用Redis分布式锁实现主备

    使用Redis分布式锁实现集群的主备 最近工作中遇到一个问题,我们会调用业务部门提供的HTTP接口获取所有的音视频任务信息,这些任务会被分发到各个机器节点进行处理.有两个方案: 方案一 为每台机器编号 ...

  2. Java Spring Cloud 实战之路 - 1 创建项目

    0. 前言 该项目使用Maven进行管理和构建,所以需要预先配置好Maven.嗯,在这个系列里就不做过多的介绍了. 1. 创建项目 先创建一个pom.xml 文件,添加以下内容: <?xml v ...

  3. 关于zabbix利用snmp协议从交换机获取的端口带宽数据的概念问题

    关于zabbix利用snmp协议从交换机获取的端口带宽数据的概念问题:使用端口OID号获得的数据实际是即时的端口总数据量,而在计算带宽时,需要选择一个时间段,在时间段的结束点获得的总数据量减去在时间段 ...

  4. Rocket - config - Keys & Params

    https://mp.weixin.qq.com/s/Y42EWrO7IoHRD_yHD4iRLA   介绍配置项.配置值以及他们的使用方式.   参考链接: https://docs.qq.com/ ...

  5. 蒲公英 · JELLY技术周刊 Vol.09 StackOverflow - 2020 开发者年度报告

    登高远眺 沧海拾遗,积跬步以至千里 基础技术 StackOverFlow 2020 年开发者报告 技术问答社区 StackOverFlow 的年度报告,本次报告统计了来自于全球各地共 65000 名开 ...

  6. Java实现蓝桥杯算法提高P0102

    算法提高 P0102 时间限制:1.0s 内存限制:256.0MB 提交此题 用户输入三个字符,每个字符取值范围是0-9,A-F.然后程序会把这三个字符转化为相应的十六进制整数,并分别以十六进制,十进 ...

  7. Java实现 LeetCode 312 戳气球

    312. 戳气球 有 n 个气球,编号为0 到 n-1,每个气球上都标有一个数字,这些数字存在数组 nums 中. 现在要求你戳破所有的气球.每当你戳破一个气球 i 时,你可以获得 nums[left ...

  8. java实现识别复制串

    ** 识别复制串** 代码的目标:判断一个串是否为某个基本串的简单复制构成的. 例如: abcabcabc,它由"abc"复制3次构成,则程序输出:abc aa 由"a& ...

  9. 解读三组容易混淆的Dockerfile指令

    长话短说,今天分享三组容易混淆的Dockerfile指令, 帮助大家编写更优雅的Dockfile文件.构建更纯净的Docker镜像. COPY vs ADD COPY.ADD主体功能类似:从指定位置拷 ...

  10. Spring Cloud微服务(一):公共模块的搭建

    本demo后台采用spring cloud微服务,前端选用vue,进行前后端分离搭建.具体项目见git:光头才能强 创建文件夹,并分别创建以下jar工程 创建公共模块(后续有需要,还会增加).无论是d ...