迭代器是访问集合内元素的一种方式
迭代器协议:要提供next()方法,要么返回下一个对象,要么引起一个stoplteration异常
for,max,min,sum
优点:以一种延迟计算方式返回元素。比如列表含有一千万个整数需要占400M的内存,而迭代器只需要几十个字节的空间
生成器
1.语法上和函数类似:生成器函数和常规函数几乎是一样的。它们都是使用def语句进行定义,差别在于,生成器使用yield语句返回一个值,而常规函数使用return语句返回一个值
2.自动实现迭代器协议:对于生成器,Python会自动实现迭代器协议,以便应用到迭代背景中(如for循环,sum函数)。由于生成器自动实现了迭代器协议,所以,我们可以调用它的next方法,并且,在没有值可以返回的时候,生成器自动产生StopIteration异常
3.状态挂起:生成器使用yield语句返回一个值。yield语句挂起该生成器函数的状态,保留足够的信息,以便之后从它离开的地方继续执行
4.生成器只能遍历一次
小例子
def pei():
a,b=0,1
print(b,end=' ')
for i in range(10):
a,b=b,a+b
yield b
a=pei()
for i in a:
print(i,end=' ')
@classmethod#类方法
def cm(cls):
cls.name='aa'
@staticmethod#静态方法
def cmm():
print('aa')
单例
class singleton():
__instance=None
def __new__(cls, *args, **kwargs):#构造方法
if cls.__instance==None:
cls.__instance=object.__new__(cls)
return cls.__instance
def __init__(self,name):
self.name=name
s=singleton('aaa')
print(s.name)
迭代器协议:要提供next()方法,要么返回下一个对象,要么引起一个stoplteration异常
for,max,min,sum
优点:以一种延迟计算方式返回元素。比如列表含有一千万个整数需要占400M的内存,而迭代器只需要几十个字节的空间
生成器
1.语法上和函数类似:生成器函数和常规函数几乎是一样的。它们都是使用def语句进行定义,差别在于,生成器使用yield语句返回一个值,而常规函数使用return语句返回一个值
2.自动实现迭代器协议:对于生成器,Python会自动实现迭代器协议,以便应用到迭代背景中(如for循环,sum函数)。由于生成器自动实现了迭代器协议,所以,我们可以调用它的next方法,并且,在没有值可以返回的时候,生成器自动产生StopIteration异常
3.状态挂起:生成器使用yield语句返回一个值。yield语句挂起该生成器函数的状态,保留足够的信息,以便之后从它离开的地方继续执行
4.生成器只能遍历一次
小例子
def pei():
a,b=0,1
print(b,end=' ')
for i in range(10):
a,b=b,a+b
yield b
a=pei()
for i in a:
print(i,end=' ')
@classmethod#类方法
def cm(cls):
cls.name='aa'
@staticmethod#静态方法
def cmm():
print('aa')
单例
class singleton():
__instance=None
def __new__(cls, *args, **kwargs):#构造方法
if cls.__instance==None:
cls.__instance=object.__new__(cls)
return cls.__instance
def __init__(self,name):
self.name=name
s=singleton('aaa')
print(s.name)