根据廖雪峰网站上的资料做一下笔记
在视频课里老师对于生成器有这么一句解释:生成器是先保存了计算的方法,等你需要调用的时候,就算一下,不是一次性创建完整的数据,而是每次用的时候创一个
创建列表时,受到内存限制,列表的容量是有限的。假如创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果仅仅需要访问前几个元素,那么后面大多数元素占用的空间都浪费了。
所以如果列表元素可以按照某种算法推算出来,就可以在循环的过程中推算出后面的元素,这样就不必创建完整的列表,节省很多空间。在python中,这种一边循环一边计算的机制,称为生成器:generator。
要创建一个generator,第一种方法是把一个列表生成式的[]改成(),就创建了一个generator。
>>> ls=[x*x for x in range(10)]
>>> ls
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
>>> g=(x*x for x in range(10))
>>> g
<generator object <genexpr> at 0x0000000002C979A8>
可以看到方括号和圆括号里面的东西是一样的,但是一个生成了list,一个生成了generator。
对于list的每个元素,可以直接打印出来
但是对于generator的每一个元素,需要通过next()获