我们都知道python的列表生成器,通过列表生成器我们可以直接创建一个列表,但是会受到内存的限制,创建过大的列表会很慢,占用很大的存储空间,这时候我们仅仅是需要访问前面的几个元素,那么绝大多数的空间就浪费掉了。所以我们需要一种方法来创建大列表但是又能节省存储空间。在Python中,有一种一边循环一边计算的机制,称为生成器:generator。它可以在循环的过程中不断的推算处后续的元素,并通过next()来访问元素
接下来介绍创建生成器的几种方法:
方法一:将列表生成式中的[] 变成 () 就是生成器的创建方式。
next(b)函数与b.__next__()一样的
(扩展:不用第三个空间进行两个数的交换
1. a = 10, b = 20 a , b = b, a (python中特有的方法)
2. a = 10, b = 20 a = a + b , b = a - b, a = a - b
3.使用异或 a = 10, b = 20 a = a^b b = a^b a = a^b
)
方法二:加yield关键字
任意一个函数中出现的yield关键字,这个函数就变成了生成器。并且每次循环时,遇到yield会停止,并把yield后面的数值返回回去,等到调用了next()函数,再次进行循环,依次循环,直至遍历至最后一个值
send方法跟生成器的注意点:
1.send方法在没有调用next之前使用,需要传入None参数,否则运行报错
2.send方法如果不需要打印时,传入了参数也看不出效果。