在容器类中,当我想迭代其项目(或其项目的变换或其项目的子集)时,我可以编写生成器(如{{1} })或返回生成器(如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)
将信息传递到生成器。
显然两种方式都表现相同(在表面)。
哪种方法更可取?为什么?
哪种方法创造的更少 开销还是有其他优点我没有发现?
答案 0 :(得分:2)
生成器理解(例如在g()
中)会稍快一些。
如果你的逻辑比你提供的简单例子更复杂,那么显式循环(例如在f()
中)可能会更具可读性。
除此之外,我无法想到任何重大差异。
但请记住他们说的话:
过早优化是万恶之源!