什么時候constexpr函數在編譯時得到評估?由于在運行時可能會調用聲明為constexpr的函數,編譯器在哪個條件下決定是在編譯時還是在運行時計算它?template<typename base_t, typename expo_t>constexpr base_t POW(base_t base, expo_t expo){
return (expo != 0 )? base * POW(base, expo -1) : 1;}int main(int argc, char** argv){
int i = 0;
std::cin >> i;
std::cout << POW(i, 2) << std::endl;
return 0;}在這種情況下,我在編譯時是未知的,這可能是編譯器將POW()視為在運行時調用的常規函數的原因。然而,這種動態雖然看起來很方便,但卻具有一些不切實際的含義。例如,是否有一種情況我希望編譯器在編譯時計算constexpr函數,編譯器決定將其視為普通函數,而它在編譯時也會工作?有任何已知的常見陷阱嗎?
2 回答

HUH函數
TA貢獻1836條經驗 獲得超4個贊
當需要常量表達式時,必須在編譯時評估該函數。
保證這一點的最簡單方法是使用constexpr
值,或std::integral_constant
:
constexpr auto result = POW(i, 2); // this should not compile since i is not a constant expressionstd::cout << result << std::endl;
要么:
std::cout << std::integral_constant<int, POW(i, 2)>::value << std::endl;
要么
#define POW_C(base, power) (std::integral_constant<decltype(POW((base), (power)), POW((base), (power))>::value)std::cout << POW_C(63, 2) << std::endl;
要么
template<int base, int power>struct POW_C { static constexpr int value = POW(base, power);};std::cout << POW_C<2, 63>::value << std::endl;
- 2 回答
- 0 關注
- 488 瀏覽
添加回答
舉報
0/150
提交
取消