std::is_scoped_enum
來自 cppreference.com
定義於標頭檔案 <type_traits> |
||
template< class T > struct is_scoped_enum; |
(C++23 起) | |
std::is_scoped_enum
是一個 一元型別特性。
檢查 T
是否是有作用域的列舉型別。提供成員常量 value
,如果 T
是有作用域的列舉型別,則其等於 true。否則,value
等於 false。
如果程式為 std::is_scoped_enum
或 std::is_scoped_enum_v
新增特化,則行為是未定義的。
目錄 |
[編輯] 模板引數
T | - | 要檢查的型別 |
[編輯] 輔助變數模板
template< class T > constexpr bool is_scoped_enum_v = is_scoped_enum<T>::value; |
(C++23 起) | |
繼承自 std::integral_constant
成員常量
值 [靜態] |
true 如果 T 是有作用域的列舉型別,否則為 false(public static 成員常量) |
成員函式
operator bool |
將物件轉換為 bool,返回 value (公開成員函式) |
operator() (C++14) |
返回 value (公開成員函式) |
成員型別
型別 | 定義 |
value_type
|
bool |
型別
|
std::integral_constant<bool, value> |
[編輯章節:注意] 注意
特性測試宏 | 值 | 標準 | 特性 |
---|---|---|---|
__cpp_lib_is_scoped_enum |
202011L |
(C++23) | std::is_scoped_enum
|
[編輯章節:可能實現] 可能實現
namespace detail { void test_conversion(...); // selected when E is complete and scoped void test_conversion(int) = delete; // selected when E is complete and unscoped template<class E> concept is_scoped_enum_impl = std::is_enum_v<E> && // checked first requires { detail::test_conversion(E{}); }; // ill-formed before overload resolution // when E is incomplete } // 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) |
檢查一個型別是否是列舉型別 (類模板) |