Template specialization for enum

后端 未结 3 1985
星月不相逢
星月不相逢 2020-12-17 23:19

Is it possible to specialize a templatized method for enums?

Something like (the invalid code below):

template 
void f(T value);

t         


        
相关标签:
3条回答
  • 2020-12-17 23:46

    I'm not sure if I understand your question correctly, but you can instantiate the template on specific enums:

    template <typename T>
    void f(T value);
    
    enum cars { ford, volvo, saab, subaru, toyota };
    enum colors { red, black, green, blue };
    
    template <>
    void f<cars>(cars) { }
    
    template <>
    void f<colors>(colors) { }
    
    int main() {
        f(ford);
        f(red);
    }
    
    0 讨论(0)
  • 2020-12-17 23:57

    Presumably, the only interesting thing you could do with a type that they only thing you know about it is that it's an enum, is cast it to its underlying type and operate on that. Here's how that might look like, using James' suggested approach (AKA SFINAE):

    void Bar(int b); // and/or other underlying types
    
    template<typename T>
    typename std::enable_if<std::is_enum<T>::value, void>::type
    Foo(T enm)
    {
        Bar(static_cast<typename std::underlying_type<T>::type>(enm));
    }
    

    As a related bonus, here's a similar method that would only get resolved for a specific type of your choosing (replace bool in is_same to the type of your choosing):

    template<typename T>
    typename std::enable_if<std::is_same<T,bool>::value, void>::type
    Baz(T bl)
    {
        if (bl)
        {
            //...
        }
        else
        {
            //...
        }
    }
    
    0 讨论(0)
  • 2020-12-18 00:00

    You can use std::enable_if with std::is_enum from <type_traits> to accomplish this.

    In an answer to one of my questions, litb posted a very detailed and well-written explanation of how this can be done with the Boost equivalents.

    0 讨论(0)
提交回复
热议问题