当且仅当传入的类型T是类枚举时,如何实现其值成员为true的类型特征?虽然我知道,例如
+T{};
如果T是枚举,将起作用,如果它是枚举类,则失败,到目前为止,我无法找到将其用于SFINAE的方法。
答案 0 :(得分:11)
根据您的+T{}
测试:
尾随返回类型中的表达式SFINAE:
#include <type_traits>
template <typename T>
auto test(int) -> decltype((void)+T{}, std::false_type{});
template <typename T>
auto test(...) -> std::true_type;
template <typename T>
using is_enum_class = std::integral_constant<bool, decltype(test<T>(0))::value && std::is_enum<T>::value>;
在 void_t-fashion :
template <typename T, typename V = void>
struct test : std::false_type {};
template <typename T>
struct test<T, decltype((void)+T{})> : std::true_type {};
template <typename T>
using is_enum_class = std::integral_constant<bool, !test<T>::value && std::is_enum<T>::value>;
试验:
enum class EC { a, b };
enum E { c, d };
int main()
{
static_assert(is_enum_class<EC>::value, "!");
static_assert(!is_enum_class<E>::value, "!");
static_assert(!is_enum_class<int>::value, "!");
}
答案 1 :(得分:6)
检查枚举是否可转换为int
。
template <class T>
using is_scoped_enum = std::integral_constant<bool, !std::is_convertible<T,int>{}
&& std::is_enum<T>{}>;
这些静态断言将成功:
enum e {};
enum class e2 {};
static_assert( is_scoped_enum<e2>::value, "" );
static_assert( !is_scoped_enum<e>::value, "" );
static_assert( !is_scoped_enum<char>::value, "" );