我有一个带有布尔模板参数的类.
template<bool b>
class Foo {
void doFoo();
};
Run Code Online (Sandbox Code Playgroud)
我想doFoo根据价值做不同的事情b.
天真我能写
选项1
template<bool b> void Foo<b>::doFoo() {
if (b) cout << "hello";
else cout << "goodbye";
}
Run Code Online (Sandbox Code Playgroud)
这对我来说似乎效率低下,因为我必须在if每次调用函数时执行一次,尽管在编译时应该知道正确的分支.我可以通过模板专业化解决这个问题:
选项2
template<> void Foo<true>::doFoo() { cout << "hello"; }
template<> void Foo<false>::doFoo() { cout << "goodbye"; }
Run Code Online (Sandbox Code Playgroud)
这样我在运行时就没有执行任何条件.这个解决方案有点复杂(特别是因为在我的实际代码中,类有几个模板参数,你不能部分地专门化函数,所以我需要将函数包装在一个类中).
我的问题是,编译器是否足够聪明,知道不执行条件选项1,因为它总是以相同的方式执行,还是需要编写特化?如果编译器足够智能,我很乐意知道这是依赖于编译器还是我可以依赖的语言功能?
Nat*_*ica 20
编译器可能会优化分支,因为它在编译时已知是什么b.但这并不能保证,唯一可以确定的方法是检查装配.
如果您可以使用C++ 17,则可以使用if constexpr并保证只存在一个分支.
这对我来说似乎效率低下,因为每次调用函数时我都必须执行if
编译器可能会对此进行优化 - 但标准并不保证.确切地说,您应该查看您关心的编译器的输出(使用您计划使用的编译选项):例如.clang在链接的示例中没有分支(未优化的版本有很多函数调用样板但没有分支).
在C++ 17中,您可以使用if constexpr,并且未编译的分支将在编译时被丢弃.
| 归档时间: |
|
| 查看次数: |
844 次 |
| 最近记录: |