在容器类中,当我想迭代它的项(或其项的转换,或其项的子集)时,可以编写生成器(如f)或返回生成器(如g):
class SomeContainer:
def __init__(self):
self.data = [1, 'two', 3, 'four']
def f(self):
for e in self.data: yield e + e
def g(self):
return (e + e for e in self.data)
sc = SomeContainer()
for x in sc.f(): print(x)
for x in sc.g(): print(x)我不需要通过send将信息传递到生成器。
显然,这两种方式(在表面上)的行为是相同的。
发布于 2013-12-15 06:17:48
生成器的理解(如在g()中)会稍微快一些。
如果您的逻辑比您提供的简单示例中的逻辑复杂,显式循环(如f()中的循环)可能更具可读性。
除此之外,我想不出任何实质性的差别。
但记住他们说的话:
过早优化是万恶之源!
https://stackoverflow.com/questions/20591544
复制相似问题