0

假设我有一个函数,它需要相当长的时间才能运行。主要是我想用相同的参数多次调用这个函数。

我的最终问题是,我应该将返回值存储在一个变量中并使用它还是只是多次调用该函数?哪种方式需要更少的计算?

现代语言的编译器(如果有的话)是否能够判断一个函数是否是纯函数?如果是,编译器是否能够优化同一块中的多个调用?如果是,那么我只调用这些函数比使用占位符变量更有意义(因为我将浪费计算来执行赋值/绑定名称)?

编辑:这是一个例子

if myPureFunction(a,b) == 1:
    print(1)
elif myPureFunction(a,b) == 2:
    print(2)
elif myPureFunction(a,b) == 3:
    print(3)
else:
    print(4)

对比

var = myPureFunction(a,b) 
if var == 1:
    print(1)
elif var == 2:
    print(2)
elif var == 3:
    print(3)
else:
    print(4)

提前致谢。

4

2 回答 2

1

您的答案取决于编译器的优化。如果函数“myPureFunction()”的主体在同一个翻译单元(您的 C 文件)中,那么一些编译器可以对第一个示例执行优化并将 3x 函数调用替换为仅一个。但并非所有编译器都可以进行这种优化,第二个变体会更好。我这么说是因为我们的编译器(我在工作中实现的那个)做不到=)

于 2013-08-25T20:40:36.070 回答
-1

我认为您可能正在寻找的答案是递归。这意味着多次调用同一个函数,但是每次调用都会分解问题。(但老实说,我并不完全理解你的实际问题是什么)

这是一个来自 TheNewBoston 的简单递归示例,可能会对您有所帮助。

https://www.youtube.com/watch?v=fpuWkZs51aM

于 2013-08-23T18:23:50.773 回答