举个例子:
class something { public: static constexpr int seconds(int hour, int min, int sec) { return hour*3600+min*60+sec; } }
然后:
printf("Look at the time: %d\n", something::seconds(10, 0, 0));
将编译为使用g ++调用函数,而不是使用常数.为什么g ++会这样做?它没有任何好处,有点挫败了使用constexpr而不是糟糕的宏的目的.
为什么g ++会这样做?
constexpr
在将结果用作常量表达式的情况下,必须在编译时评估函数.这些包括初始化constexpr
变量和用作模板参数.
在其他情况下,即使constexpr
使用自身都是常量表达式的参数调用函数,也可以由实现来执行它想要的操作.通常,它将取决于优化标志.例如,在gcc 6.2和clang 3.9.1上,-O0
将在运行时发出一个调用,但-O1
会发出常量36000
.