迭代器
class Die():
def __init__(self):
self.name = ['a','b','c']
self.num = 0
def __iter__(self):
return self
def __next__(self):
while True:
self.num +=1
if self.num < len(self.name):
return self.name[self.num]
else:
raise StopIteration
生成器
def feibonacci(n):
a,b = 0,1
num = 0
while num <n:
yield a
a,b = b,a+b
num+=1
总结:
迭代器
1.迭代器需要类中实现两个方法__iter__和__next__
2.实现了__iter__方法的对象,称为可迭代对象,
3.__iter__方法的返回值,返回一个迭代器对象
4.既实现__iter__和__next的对象称为迭代器
生成器
函数中含有yield的称为生成器,生成器主要是节省空间,当只有被调用的时候才执行,在内存方面有很大的优势