执行生成器表达式的最pythonic方法是什么?

执行生成器表达式的最pythonic方法是什么?,第1张

执行生成器表达式的最pythonic方法是什么?

现在是2019年-这是2010年以来不断出现的一个问题。一个在Python的邮件列表,最近垃圾邮件的线程在这个问题上超过70封电子邮件,他们再次拒绝了一个添加

consume
调用语言。

在该线程上,实际上显示了该模式下最有效的模式,并且它远非显而易见,因此我将其发布为答案:

import dequeconsume = deque(maxlen=0).extend

然后使用

consume
callable处理生成器表达式。

事实证明

deque
,cPython中的本机代码实际上针对这种
maxlen=0
情况进行了优化,并且只会消耗可迭代的代码。我在问题中提到
any
all
调用应该同样有效,但是必须担心表达式的真实性才能消耗可迭代项。


我看到这仍然可能是有争议的,毕竟,显式的两行循环可以解决这个问题-我记得这个问题,因为我刚刚提交了一个创建一些线程,然后启动,然后再联接然后返回的提交-没有

consume
可调用的内容,是4行,大部分都是样板,并且没有从通过本机代码中的迭代过程中受益:https
:
//github.com/jsbueno/extracontext/blob/a5d24be882f9aa18eb19effe3c2cf20c42135ed8/tests/test_thread.py#L27



欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5668476.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存