constexpr函数需在编译期求值,提升性能;2. 函数体仅限声明、return、空语句等简单操作;3. C++11不支持局部静态变量,C++14起允许且需常量初始化;4. 参数与返回类型须为字面类型;5. C++14起支持循环与递归,可实现编译期阶乘等计算。
在C++中,constexpr函数用于支持编译期计算,允许在编译阶段求值表达式,从而提升运行时性能并实现类型系统层面的优化。但为了保证可预测性和安全性,编译器对constexpr函数的编写有严格限制。了解这些限制是编写高效、合规的编译期计算函数的关键。
constexpr函数并非所有C++语句都可使用。从C++11到C++20,标准逐步放宽了限制,但仍需遵守基本规范:
goto语句和try-catch异常处理块(C++23前)例如,以下代码在C++11中非法,但在C++14及以上合法:
constexpr int func() {constexpr函数的参数和返回类型必须是字面类型,即可以在编译期确定的类型。常见字面类型包括:
int、double、bool)如果函数接受或返回复杂对象(如std::string或动态容器),则无法在编译期求值,除非使用C++20引入的更宽松规则(如constev或支持动态内存的
alconstexpr分配)。
早期C++11只允许条件表达式(如三元运算符)进行“伪递归”,不允许传统循环。但从C++14开始,constexpr函数可以使用:
for、while循环这意味着你可以编写像阶乘、斐波那契这样的编译期计算函数:
constexpr long long factorial(int n) {只要调用时传入的是常量表达式(如factorial(5)),结果将在编译期完成计算。
constexpr函数内部只能调用其他constexpr函数或语言内置操作。调用普通函数或带有副作用的函数会导致编译错误:
printf、new(C++14前)、virtual函数等constexpr,使用前需确认版本支持例如,std::sqrt直到C++26才计划成为constexpr,此前无法在constexpr上下文中使用。
基本上就这些。编写constexpr函数时,关键是保持逻辑简单、类型明确,并依赖标准演进带来的新能力。不复杂但容易忽略。