std::is_scoped_enum
来自cppreference.com
<tbody>
</tbody>
| 在标头 <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 | - | 要检查的类型 |
辅助变量模板
<tbody> </tbody> template< class T > constexpr bool 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);
enum struct C { final, import, module };
static_assert(std::is_scoped_enum_v<C> == true);
enum class D : int { pre, post, override };
static_assert(std::is_scoped_enum_v<D> == true);
enum class E;
static_assert(std::is_scoped_enum_v<E> == true);
int main() {}
参阅
(C++11) |
检查类型是否为整数类型 (类模板) |
(C++11) |
检查类型是否为算术类型 (类模板) |
(C++11) |
检查类型是否为标量类型 (类模板) |
(C++11) |
检查类型是否为枚举类型 (类模板) |