如何实现is_enum_class类型特征
How to implement is_enum_class type trait?
当
且仅当传入的类型 T 是类枚举时,如何实现其值成员为真的类型特征?虽然我知道例如
+T{};
如果 T 是枚举,则工作,如果它是枚举类,则失败,到目前为止,我找不到将其用于 SFINAE 的方法。
根据你的+T{}
测试:
选项#1:
尾随返回类型中的表达式 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>;
演示
选项#2:
void_t时尚:
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>;
演示 2
测试:
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, "!");
}
检查枚举是否可以转换为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, "" );
演示。
相关文章:
- enum是C++中的宏变量还是整数变量
- 是否可以从int转换为enum类类型
- 在一个模板函数中,若输入的类型是enum类,我该如何使用std::underlying_type
- 这个语法std::class<>{}(arg1, arg2) 在C++中是什么意思?
- C++核心准则 C35 对于接口类"A base class destructor should be either public and virtual, or protected and nonv
- 使用模板进行堆栈实现; "name followed by :: must be a class or namespace"
- "Undefined class"作为is_base_of的论据
- 如何将class.cpp和class.hpp编译为一个.o文件
- 在C++中,将int值赋给enum,反之亦然
- 两个 COM 组件中 ENUM 的重复条目
- 将枚举类型保存在位字段 [dcl.enum] [class.bit] 中
- 如何 std::map<enum class, std::string>?
- "enum class"是C++中的类类型吗?
- "enum class" Visual C++ 2012 中是什么意思?
- C++:使用"enum class"的类内部的枚举
- 我可以在DLL边界使用“enum class”作为函数的参数类型吗
- Month的表示:enum class与class
- 是否可以使作用域枚举("enum class")在上下文中可转换为布尔值?
- Class-scoped enum
- 如何访问封装在类中的未命名"enum class"?