如何解决列表理解内的函数-被评估多次[重复]
|| 这个问题已经在这里有了答案:解决方法
我可能会选择后者,因为Python编译器不知道该函数是否具有副作用,因此将为每个元素调用该函数。
, 它会为每次迭代进行评估。看这个:
>>> def f():
... print(\"func\")
...
>>> [f() for i in range(4)]
func
func
func
func
[None,None,None]
就像您说的那样,如果f()没有副作用,那么将返回值存储在变量上并使用该变量将是更快的解决方案。
, 这是一种简单的查找方法:
>>> def f():
... print \"called\"
... return 1
...
>>> [1+f() for x in xrange(5)]
called
called
called
called
called
[2,2,2]
所以是的,如果函数每次都相同,那么最好在列表理解之外调用一次。
, 将为每个元素调用函数“ 2”。
, 对于编译器/解释器来说,确定不需要多次调用该函数非常复杂。然后很有可能多次调用该函数。因此,使用第二种解决方案始终是最佳解决方案。
, 与名称查找相比,函数具有不平凡的执行时间,如果多次调用函数并且每次均期望值相同,则缓存值被认为是可以接受的。
, Python可能可以自由地执行一次或多次,我不确定我是否会依赖于任何观察到的行为。在下一版本中可能会更改。
如果对确保函数仅被调用一次很重要,请自己调用并保存结果。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。