constexpr说明符的性能未达到我在C ++中的期望

时间:2018-10-07 03:30:18

标签: c++ visual-studio c++11 c++14 compiler-optimization

我刚刚了解到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;
}

1 个答案:

答案 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);