迭代模式:对外提供一个接口,实现顺序访问聚合数据,但是不显示该数据的内部机制。这就是Python中大名鼎鼎的迭代器。
实现迭代模式对于Python来说没有多余的代码,寥寥几行代码足可以实现迭代模式。
示例code:
# -*- coding:utf-8 -*-
def FibonacciSequence(n):
x = 0
y = 1
i = 1
while True:
yield y
if i == n:
break
x, y = y, x+y
i += 1
if __name__ == '__main__':
test = FibonacciSequence(7)
next(test)
1
next(test)
1
next(test)
2
next(test)
3
next(test)
5
next(test)
8
next(test)
13
next(test)
以上是使用迭代模式输出斐波那契数列的前n列,较传统的实现方法而言更加的简洁。
迭代器模式常应用场景是在只提供接口而不暴露内部机制的场景中,yield关键词在python协程中也有应用。
迭代器、生成器、可迭代对象概念
生成器:对于一个数据集合,生成器并不记住每个元素值,但在循环中记录元素位置并根据元素生成规则推算出数值,这种边循环边计算的形式是生成器。
迭代器:是一种访问集合的方式,记住遍历位置,从第一个元素开始访问