在Python中,生成器(Generator)是一种特殊的函数,它使用 yield 语句来产生一个值的序列,而不是一次性返回完整的结果集。
生成器函数在被调用时返回一个生成器对象,它可以用于迭代产生值。每次调用生成器的__next__()
方法(在Python 2中为next()
方法)时,它会执行生成器函数的代码,直到遇到yield语句。yield语句会暂停函数的执行,并将 yield 后面的表达式作为当前迭代的值返回。在下一次调用__next__()
方法时,生成器会从暂停的位置继续执行,直到遇到下一个 yield 语句。
生成器函数可以用于按需生成大量的数据或遍历大型数据集,而不需要一次性将它们全部加载到内存中。这在处理大型数据或无穷序列时非常有用,可以节省内存空间并提高性能。
以下是一个简单的生成器函数的示例,它生成了一个斐波那契数列:
def fibonacci():
a, b = 0, 1
while True:
yield a
a, b = b, a + b
通过调用该生成器函数,我们可以获取斐波那契数列的值,如下所示:
fib = fibonacci()
print(next(fib)) # 输出: 0
print(next(fib)) # 输出: 1
print(next(fib)) # 输出: 1
print(next(fib)) # 输出: 2
...