std::is_scoped_enum
来自cppreference.com
在标头 <type_traits> 定义 | ||
template<class T > struct is_scoped_enum; | (C++23 起) | |
std::is_scoped_enum
是一元类型特征(UnaryTypeTrait) 。
检查 T
是否为有作用域枚举类型。如果 T
是有作用域枚举类型,那么提供的成员常量 value
等于 true。否则,value
等于 false。
如果程序添加了 std::is_scoped_enum
或 std::is_scoped_enum_v
的特化,那么行为未定义。
目录 |
[编辑]模板形参
T | - | 要检查的类型 |
[编辑]辅助变量模板
template<class T > constexprbool is_scoped_enum_v = is_scoped_enum<T>::value; | (C++23 起) | |
继承自 std::integral_constant
成员常量
value [静态] | 如果 T 是有作用域枚举类型那么是 true,否则是 false(公开静态成员常量) |
成员函数
operator bool | 将对象转换到 bool,返回 value (公开成员函数) |
operator() (C++14) | 返回 value (公开成员函数) |
成员类型
类型 | 定义 |
value_type | bool |
type | std::integral_constant<bool, value> |
[编辑]注解
功能特性测试宏 | 值 | 标准 | 功能特性 |
---|---|---|---|
__cpp_lib_is_scoped_enum | 202011L | (C++23) | std::is_scoped_enum |
[编辑]可能的实现
namespace detail {void test_conversion(...);// 在 E 完整且为有作用域时得到选择void test_conversion(int)= delete;// 在 E 完整且为无作用域时得到选择 template<class E> concept is_scoped_enum_impl =std::is_enum_v<E>&&// 首先检查 requires { detail::test_conversion(E{});};// 当 E 不完整时在重载决议前非良构}// namespace detail template<class T>struct is_scoped_enum :std::bool_constant<detail::is_scoped_enum_impl<T>>{}; |
[编辑]示例
运行此代码
#include <type_traits> static_assert(std::is_scoped_enum_v<int>==false); class A {}; static_assert(std::is_scoped_enum_v<A>==false); enum B { self_test = std::is_scoped_enum_v<B>}; static_assert(std::is_scoped_enum_v<B>==false); static_assert(!self_test); enumstruct C { final, import, module }; static_assert(std::is_scoped_enum_v<C>==true); enumclass D :int{ pre, post, override }; static_assert(std::is_scoped_enum_v<D>==true); enumclass E; static_assert(std::is_scoped_enum_v<E>==true); int main(){}
[编辑]参阅
(C++11) | 检查类型是否为整数类型 (类模板) |
(C++11) | 检查类型是否为算术类型 (类模板) |
(C++11) | 检查类型是否为标量类型 (类模板) |
(C++11) | 检查类型是否为枚举类型 (类模板) |