编译时未知的 constexpr 函数参数布尔值 C++
我需要运行一个带有 N 个布尔变量的函数,我想让它们 constexpr 以消除比较并从分支预测失败中保存代码。
我的意思是:
templateFunc<b1, b2, b3, b4 ...>(args...);
由于 b1..bn 变量只是布尔变量并且可能只有 2 个状态,我可以这样写:
if (b1 && b2)
templateFunc<true, true>(args...);
else if (b1 && !b2)
templateFunc<true, false>(args...);
else if (!b1 && b2)
templateFunc<false, true>(args...);
else
templateFunc<false, false>(args...);
问题很明显,我需要对 5 个变量进行 64 次调用。有什么解决方案吗?
回答
使用std::variant(C++17),您可以通过std::visit以下方式进行动态分派:
// helper
std::variant<std::false_type, std::true_type> to_boolean_type(bool b)
{
if (b) return std::true_type{};
return std::false_type{};
}
进而
std::visit([&](auto... bs){templateFunc<bs...>(args...);},
to_boolean_type(b1), to_boolean_type(b2));
演示