std::is_compound
来自cppreference.com
<tbody>
</tbody>
| 在标头 <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 | - | 要检查的类型 |
辅助变量模板
<tbody> </tbody> template< class T > constexpr bool is_compound_v = is_compound<T>::value; |
(C++17 起) | |
继承自 std::integral_constant
成员常量
value [静态] |
如果 T 为复合类型那么是 true,否则是 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 << "通过所有检查\n";
}
参阅
(C++11) |
检查类型是否为基础类型 (类模板) |
(C++11) |
检查类型是否为标量类型 (类模板) |
(C++11) |
检查类型是否为对象类型 (类模板) |
(C++11) |
检查类型是否为数组类型 (类模板) |