确保模板参数是枚举类

时间:2016-10-01 14:12:29

标签: c++ c++11 template-meta-programming

有没有办法确保模板参数是枚举类型?

我知道type_traitsstd::is_enum,但我不希望它与常规枚举相匹配,只是enum_classes。

想要的效果示例:

enum class EnumClass {};
enum Enum {};
class Class {};

template <typename T>
void Example()
{
    static_assert(/* T is EnumClass */, "`T` must be an enum class");
}

Example<EnumClass>(); // Ok
Example<Enum>(); // Error
Example<Class>(); // Error

我正在使用C ++ 11,遗憾的是不能再高了(虽然我很想知道解决方案,即使它涉及更新的标准)。

有可能吗?

1 个答案:

答案 0 :(得分:20)

您可以通过以下方式实现:

template<typename T>
using is_class_enum = std::integral_constant<
   bool,
   std::is_enum<T>::value && !std::is_convertible<T, int>::value>;

Here演示。

如果您更喜欢使用SFINAE,可以通过以下方式实现:

template<typename T, typename _ = void>
struct is_class_enum : std::false_type {
};

template<typename T>
struct is_class_enum <
  T,
  typename std::enable_if<std::is_enum<T>::value &&
                          !std::is_convertible<T, int>::value>::type> :
    public std::true_type {
};