我刚刚了解到constexpr指定符函数可以在编译过程中运行,我尝试使用Debug x86 Mode检查VS 2017中的实际性能,结果表明它们之间的时间差很小。它仍然花费了很多时间而不是“ 0”。我做错了什么,有谁可以帮助我,非常感谢!
#include <iostream>
#include <time.h>
size_t r_fun(size_t n) noexcept
{
if (n == 0) return 0;
if (n == 1) return 1;
return r_fun(n - 1) + r_fun(n - 2);
}
constexpr size_t c_fun(size_t n) noexcept
{
if (n == 0) return 0;
if (n == 1) return 1;
return c_fun(n - 1) + c_fun(n - 2);
}
int main()
{
clock_t start, finish;
start = clock();
auto r_x = r_fun(40);
finish = clock();
std::cout <<"result:"<< r_x<< "\ttime:" << (double)(finish - start) << std::endl;
start = clock();
static const auto c_x = c_fun(40);
finish = clock();
std::cout << "result:" << c_x << "\ttime:" << (double)(finish - start) << std::endl;
return 0;
}
答案 0 :(得分:6)
您的constexpr
函数需要太多的计算才能在编译器中执行,这就是为什么编译器选择将其延迟到运行时执行的原因。
您可以更改此行:
static const auto c_x = c_fun(40);
收件人:
constexpr auto c_x = c_fun(40);
查看编译器的输出。在c上,它告诉我:
note: constexpr evaluation hit maximum step limit;
c_x
确实是一个编译时常量,但是由于实现限制,编译器无法对其进行计算。请注意,您的函数具有指数复杂性。
Everything will be fine,如果您将40更改为某个合理的数字,例如10:
constexpr auto c_x = c_fun(10);