您的位置:首页 > 其它

decorator & generator & iterator

2015-07-23 16:39 344 查看
装饰器(decorator): @staticmethod @classmethod 都既可以使用类名访问,也可以使用对象名访问, 但classmethod在定义时需要cls参数

生成器(generator): 任何包含yield语句的函数成为生成器。

迭代器(iterator):一个实现了__iter__()方法的对象是可迭代的,一个实现了next方法的对象是迭代器。

for item in Fibs(): next()方法和__iter__()方法缺一不可;__iter()仅调用一次, next()调用多次(有多少个元素就调用多少次)

decorator & generator是针对方法而言的,iterator是针对类(对象)而言的。

#!/usr/bin/python2.7
#coding:utf-8
#如果想有中文注释就必须得有上面的语句
__metaclass__ = type

#generator
def countDown(n):
print("Start to count from " + str(n))
while n > 0:
yield n
n -= 1
print("Done!")

#iterator
#迭代器(iterator):一个实现了__iter__()方法的对象是可迭代的,一个实现了next方法的对象是迭代器。
#for item in Fibs():  next()方法和__iter__()方法缺一不可;__iter__()仅调用一次, next()调用多次(有多少个元素就调用多少次)
class Fibs(object):
def __init__(self):
self.a = 1
self.b = 1

#如果没有next(), 有__iter__()提示如下错误
#TypeError: iter() returned non-iterator of type 'Fibs'
def next(self):
print("in next()")
self.a, self.b = self.b, self.a + self.b
return self.a

#如果没有__iter__()(不管有没有next())则提示如下错误
#TypeError: 'Fibs' object is not iterable
def __iter__(self):
print("in __iter__()")
return self

def main():
for item in countDown(10):
print(item)

print("")   #newline

print(type(Fibs))       #<type 'type'>
print(type(Fibs()))     #<class '__main__.Fibs'>

for fib in Fibs():
if fib > 1000:
print(fib)
break

if __name__ == '__main__':
main()
else:
print("Being imported as a module.")
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: