在 constexpr 分支中使用枚举类值

psb*_*psb 2 c++ enums constexpr c++17 tag-dispatching

下面的代码会val2在两次f()调用中打印。f()根据枚举值执行特定分支的正确方法是什么?

enum class E
{
    val1,
    val2
};

using val1_t = std::integral_constant<E, E::val1>;
using val2_t = std::integral_constant<E, E::val2>;
    

template <typename T>
void f(T t)
{
    if constexpr (std::is_same_v<T, val1_t>)
    {
        std::cerr << "val1\n";
    }
    else
    {
        std::cerr << "val2\n";
    }
}


int main()
{
    f(E::val1);
    f(E::val2);
}
Run Code Online (Sandbox Code Playgroud)

Nat*_*ica 10

如果将枚举移到模板参数中,那么您可以使用

template <E val>
void f()
{
    if constexpr (val == E::val1)
    {
        std::cerr << "val1\n";
    }
    else
    {
        std::cerr << "val2\n";
    }
}
Run Code Online (Sandbox Code Playgroud)

你会像这样使用它

int main()
{
    f<E::val1>();
    f<E::val2>();
}
Run Code Online (Sandbox Code Playgroud)