列表理解内的函数-被评估多次[重复]

||                                                                                                                   这个问题已经在这里有了答案:                                                      
已邀请:
        我可能会选择后者,因为Python编译器不知道该函数是否具有副作用,因此将为每个元素调用该函数。     
        它会为每次迭代进行评估。看这个:
>>> def f():
...     print(\"func\")
... 
>>> [f() for i in range(4)]
func
func
func
func
[None, 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, 2]
所以是的,如果函数每次都相同,那么最好在列表理解之外调用一次。     
        将为每个元素调用函数“ 2”。     
        对于编译器/解释器来说,确定不需要多次调用该函数非常复杂。然后很有可能多次调用该函数。因此,使用第二种解决方案始终是最佳解决方案。     
        与名称查找相比,函数具有不平凡的执行时间,如果多次调用函数并且每次均期望值相同,则缓存值被认为是可以接受的。     
        Python可能可以自由地执行一次或多次,我不确定我是否会依赖于任何观察到的行为。在下一版本中可能会更改。 如果对确保函数仅被调用一次很重要,请自己调用并保存结果。     

要回复问题请先登录注册