选 if constexpr 还是 SFINAE 取决于需求:需编译期分支逻辑用 if constexpr;需控制函数模板是否参与重载决议则用 SFINAE。前者用于同一模板内条件执行,后者用于使函数“消失”或“出现”,二者互补而非替代。

选 if constexpr 还是 SFINAE,关键看场景:需要编译期分支逻辑就用 if constexpr;需要控制函数模板是否参与重载决议(比如实现类型特征、多态接口或回退机制)就用 SFINAE。
用 if constexpr 的情况:同一模板内做条件编译
当你已经在一个函数模板里,只是想根据类型或常量表达式决定执行哪段代码,且两分支不互相干扰(比如一个分支调用 .size(),另一个调用 .length()),if constexpr 更简洁安全。
- 分支中非法代码不会导致编译错误,只要该分支不被选中
- 不改变重载集,不涉及函数可见性问题
- 可读性强,接近普通 if,适合逻辑分叉而非接口适配
例如:
template<typename T>
auto get_size(const T& t) {
if constexpr (has_size_v<T>) {
return t.size(); // 只有 T 有 size() 才实例化这行
} else if constexpr (is_array_v<T>) {
return std::extent_v<T>;
} else {
static_assert(always_false_v<T>, "type has no size");
}
}登录后复制
用 SFINAE 的情况:让函数模板“消失”或“出现”
当你要让某个函数模板只对特定类型可用(比如只接受迭代器、只支持移动构造、或提供 fallback 实现),必须靠 SFINAE 控制模板是否进入重载候选集。
立即学习“C++免费学习笔记(深入)”;
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~