std::is_compound
来自 cppreference.com
定义在头文件 <type_traits> 中 |
||
template< class T > struct is_compound; |
(自 C++11 起) | |
std::is_compound
是一个 UnaryTypeTrait.
如果 T
是一个复合类型(即数组、函数、对象指针、函数指针、成员对象指针、成员函数指针、引用、类、联合或枚举,包括任何 cv 限定变体),则提供成员常量 value
等于 true。对于任何其他类型,value
为 false.
如果程序为 std::is_compound
或 std::is_compound_v
添加了专门化,则行为未定义。
内容 |
[编辑] 模板参数
T | - | 要检查的类型 |
[编辑] 帮助程序变量模板
template< class T > constexpr bool is_compound_v = is_compound<T>::value; |
(自 C++17 起) | |
继承自 std::integral_constant
成员常量
value [static] |
true 如果 T 是一个复合类型,否则为 false(公共静态成员常量) |
成员函数
operator bool |
将对象转换为 bool,返回 value (公共成员函数) |
operator() (C++14) |
返回 value (公共成员函数) |
成员类型
类型 | 定义 |
value_type
|
bool |
type
|
std::integral_constant<bool, value> |
[编辑] 说明
复合类型是从基本类型构造的类型。任何 C++ 类型要么是基本类型,要么是复合类型。
[编辑] 可能的实现
template<class T> struct is_compound : std::integral_constant<bool, !std::is_fundamental<T>::value> {}; |
[编辑] 示例
运行此代码
#include <type_traits> #include <iostream> static_assert(not std::is_compound_v<int>); static_assert(std::is_compound_v<int*>); static_assert(std::is_compound_v<int&>); void f(); static_assert(std::is_compound_v<decltype(f)>); static_assert(std::is_compound_v<decltype(&f)>); static_assert(std::is_compound_v<char[100]>); class C {}; static_assert(std::is_compound_v<C>); union U {}; static_assert(std::is_compound_v<U>); enum struct E { e }; static_assert(std::is_compound_v<E>); static_assert(std::is_compound_v<decltype(E::e)>); struct S { int i : 8; int j; void foo(); }; static_assert(not std::is_compound_v<decltype(S::i)>); static_assert(not std::is_compound_v<decltype(S::j)>); static_assert(std::is_compound_v<decltype(&S::j)>); static_assert(std::is_compound_v<decltype(&S::foo)>); int main() { std::cout << "All checks have passed\n"; }
[编辑] 另请参阅
(C++11) |
检查类型是否为基本类型 (类模板) |
(C++11) |
检查类型是否为标量类型 (类模板) |
(C++11) |
检查类型是否为对象类型 (类模板) |
(C++11) |
检查类型是否为数组类型 (类模板) |