普通函数采用return返回值
def func(): print("111") return 222 #return返回一个值
ret =func() print(ret)
结果:
111
222
结果:
<generator object func at 0x0000024277AB44A0>
通过执行 __next__() 来执行以下生成器
结果:
111
222
yield是分段来执行一个函数,而return是直接停止执行函数
def func(): print("111") yield 222 print("333") yield 444 mygenerator=func() ret=mygenerator.__next__() print(ret) ret=mygenerator.__next__() print(ret) ret=mygenerator.__next__() #最后一个yield执行完毕,再次__next__()程序会报错 print(ret)
def func(): print(111) yield 222 print(333) yield 444 print(555) yield 666 gen=func() for i in gen: print(i)
结果:
111 222 333 444 555 666
>>> gen =(i for i in range(10)) >>> type(gen) <class 'generator'> >>> gen.__next__() 0 >>> gen.__next__() 1 >>> gen.__next__() 2 >>> gen.__next__() 3
生成器的特点:
惰性机制,生成器并不立即产生全部元素,仅在用到元素的时候才生成(只能向前),可以极大节省内存。
https://www.cnblogs.com/mlhz/p/9469124.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。