python 生成器实现斐波那契数列。

def fib(n):
    one=0
    two=1
    while n>0:
        one,two=two,one+two
        n-=1
        yield two

print [i for i in fib(10)]
print next(fib(10))

结果#

[1, 2, 3, 5, 8, 13, 21, 34, 55, 89]
1

*****迭代海量数据时,显然生成器更合适

什么是生成器

普通函数用 return 返回一个值,和 Java 等其他语言是一样的,然而在 Python 中还有一种函数,用关键字 yield 来返回值,这种函数叫生成器函数,函数被调用时会返回一个生成器对象,生成器本质上还是一个迭代器,也是用在迭代操作中,因此它有和迭代器一样的特性,唯一的区别在于实现方式上不一样,后者更加简洁。

生成器对象的行为和迭代器是非常相似的,可以用在 for 循环等场景中。注意 yield 对应的值在函数被调用时不会立刻返回,而是调用next方法时(本质上 for 循环也是调用 next 方法)才返回