Python3-设计模式-迭代器模式
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-设计模式-迭代器模式的更多相关文章
- 19. 星际争霸之php设计模式--迭代器模式
题记==============================================================================本php设计模式专辑来源于博客(jymo ...
- java设计模式——迭代器模式
一. 定义与类型 定义:提供一种方法,顺序访问一个集合对象中的各个元素,而又不暴露该对象的内部表示 类型:行为型. 二. 使用场景 (1) 访问一个集合对象的内容而无需暴露它的内部表示 (2) 为遍 ...
- [Head First设计模式]生活中学设计模式——迭代器模式
系列文章 [Head First设计模式]山西面馆中的设计模式——装饰者模式 [Head First设计模式]山西面馆中的设计模式——观察者模式 [Head First设计模式]山西面馆中的设计模式— ...
- JAVA 设计模式 迭代器模式
用途 迭代器模式 (Iterator) 提供一种方法顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部表示. 迭代器模式是一种行为型模式. 结构
- 深入浅出设计模式——迭代器模式(Iterator Pattern)
模式动机 一个聚合对象,如一个列表(List)或者一个集合(Set),应该提供一种方法来让别人可以访问它的元素,而又不需要暴露它的内部结构.针对不同的需要,可能还要以不同的方式遍历整个聚合对象,但是我 ...
- JavaScript设计模式 - 迭代器模式
迭代器模式是指提供一种方法顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示. 迭代器模式可以把迭代的过程从业务逻辑中分离出来,在使用迭代器模式之后,即使不关心对象的内部构造,也可以按顺 ...
- javascript设计模式-迭代器模式(Iterator)
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 设计模式 --迭代器模式(Iterator)
能够游走于聚合内的每一个元素,同时还可以提供多种不同的遍历方式. 基本概念: 就是提供一种方法顺序访问一个聚合对象中的各个元素,而不是暴露其内部的表示. 使用迭代器模式的优点: 遍历集合或者数 ...
- js设计模式--迭代器模式
迭代器模式: 迭代器模式提供一种方法顺序访问一个聚合对象中各个元素,而又不需要暴露该方法中的内部表示.js中我们经常会封装一个each函数用来实现迭代器. 理解的意思:提供一个方法,去把对象的每一项按 ...
- javascript设计模式——迭代器模式
前面的话 迭代器模式是指提供一种方法顺序访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示.迭代器模式可以把迭代的过程从业务逻辑中分离出来,在使用迭代器模式之后,即使不关心对象的内部构造,也 ...
随机推荐
- ES6-常用四种数组
1.map 1.1 个人理解 映射 一个对一个 例如:[45,57,138]与[{name:'blue',level:0},{name:'zhangsan',level:99},{name:'lisi ...
- 点击label时text输入框被选中
当点击label标签时,能够选中与其对应的输入框,有2种方式,采用第一种时会产生太多的id,推荐第二种. <form action="03.php"> <labe ...
- Spring 内部方法调用失效问题(AOP)
AOP使用的是动态代理的机制,它会给类生成一个代理类,事务的相关操作都在代理类上完成.内部方式使用this调用方式时,使用的是实例调用,并没有通过代理类调用方法,所以会导致事务失效. 解决办法 方式一 ...
- css定位和css3的基本
定位方式:position需要搭配left|right |top |bottom 1.相对定位:相对于自身的位置进行偏移position: relative; 2.绝对定位:相对于有position属 ...
- JAVASE(十二) Java常用类: 包装类、String类、StringBuffer类、时间日期API、其他类
个人博客网:https://wushaopei.github.io/ (你想要这里多有) 1.包装类 1 .1 八个包装类 1. 2 基本数据类型,包装类,String者之间的转换 2. ...
- ansible取出register变量中最长字符串
背景 在用ansible撰写一个etcd恢复的playbook时,有一个操作是获取etcd启动时的"initial-cluster"启动参数,该参数在etcd集群不同节点不一致,需 ...
- Java 第十一届 蓝桥杯 省模拟赛 小明的城堡
小明用积木搭了一个城堡. 为了方便,小明在搭的时候用的是一样大小的正方体积本,搭在了一个 n 行 m 列的方格图上,每个积木正好占据方格图的一个小方格. 当然,小明的城堡并不是平面的,而是立体的.小明 ...
- Java实现基础练习十进制转十六进制
基础练习 十进制转十六进制 时间限制:1.0s 内存限制:512.0MB 提交此题 锦囊1 锦囊2 问题描述 十六进制数是在程序设计时经常要使用到的一种整数的表示方式.它有0,1,2,3,4,5,6, ...
- Java实现 蓝桥杯VIP 算法训练 删除多余括号
算法训练 删除多余括号 时间限制:1.0s 内存限制:512.0MB 问题描述 从键盘输入一个含有括号的四则运算表达式,要求去掉可能含有的多余的括号,结果要保持原表达式中变量和运算符的相对位置不变,且 ...
- Java实现 蓝桥杯VIP 算法提高 排队打水问题
算法提高 排队打水问题 时间限制:1.0s 内存限制:256.0MB 问题描述 有n个人排队到r个水龙头去打水,他们装满水桶的时间t1.t2----tn为整数且各不相等,应如何安排他们的打水顺序才能使 ...