类型特性
类型特性定义一个编译时基于模板的结构,以查询或修改类型的属性。
试图特化定义于 <type_traits> 头文件的模板导致未定义行为,除了 std::common_type 可依照其所描述特化。
定义于<type_traits>头文件的模板可以用不完整类型实例化,除非另外有指定,尽管通常禁止以不完整类型实例化标准库模板。
类型属性
定义于头文件 <type_traits>
基础类型类别
继承自 std::integral_constant
成员常量
value [静态] | 若 T 为(可有 cv 限定的) std::nullptr_t 类型则为 true ,否则为 false(公开静态成员常量) |
成员函数
operator bool | 转换对象为 bool ,返回 value (公开成员函数) |
operator() (C++14) | 返回 value (公开成员函数) |
成员类型
类型 | 定义 |
value_type | bool |
type | std::integral_constant<bool, value> |
检查类型是否是浮点类型
std::is_floating_point
template< class T > | (C++11 起) |
检查 T
是否为浮点类型。若 T
为 float 、 double 、 long double 为浮点类型,包含任何 cv 限定变体,则提供等于 true 的成员常量 value
。否则, value
等于 false 。
模板形参
T | - | 要检查的类型 |
辅助变量模板
template< class T > | (C++17 起) |
可能的实现
template< class T >
struct is_floating_point
: std::integral_constant<
bool,
std::is_same<float, typename std::remove_cv<T>::type>::value ||
std::is_same<double, typename std::remove_cv<T>::type>::value ||
std::is_same<long double, typename std::remove_cv<T>::type>::value
> {};
检查类型是否是数组类型
std::is_array
template< class T > | (C++11 起) |
检查 T
是否数组类型。若 T
为数组类型,则提供等于 true 的成员常量 value
。否则, value
等于 false 。
模板形参
T | - | 要检查的类型 |
辅助变量模板
template< class T > | (C++17 起) |
可能的实现
template<class T>
struct is_array : std::false_type {};
template<class T>
struct is_array<T[]> : std::true_type {};
template<class T, std::size_t N>
struct is_array<T[N]> : std::true_type {};
检查类型是否是枚举类型
std::is_enum
template< class T > | (C++11 起) |
检查 T
是否为枚举类型。若 T
为枚举类型,则提供等于 true 的成员常量 value
。否则, value
等于 false 。
模板形参
T | - | 要检查的类型 |
辅助变量模板
template< class T > | (C++17 起) |
调用示例
#include <iostream>
#include <type_traits>
class A {};
enum E {};
enum class Ec : int {};
int main()
{
std::cout << std::boolalpha;
std::cout << "std::is_floating_point<A>::value: "
<< std::is_floating_point<A>::value << std::endl;
std::cout << "std::is_floating_point<float>::value: "
<< std::is_floating_point<float>::value << std::endl;
std::cout << "std::is_floating_point<double>::value: "
<< std::is_floating_point<double>::value << std::endl;
std::cout << "std::is_floating_point<long double>::value:"
<< std::is_floating_point<long double>::value << std::endl;
std::cout << "std::is_floating_point<int>::value: "
<< std::is_floating_point<int>::value << std::endl;
std::cout << std::endl;
std::cout << "std::is_array<A>::value: "
<< std::is_array<A>::value << std::endl;
std::cout << "std::is_array<A[]>::value: "
<< std::is_array<A[]>::value << std::endl;
std::cout << "std::is_array<A[3]>::value: "
<< std::is_array<A[3]>::value << std::endl;
std::cout << "std::is_array<float>::value: "
<< std::is_array<float>::value << std::endl;
std::cout << "std::is_array<int>::value: "
<< std::is_array<int>::value << std::endl;
std::cout << "std::is_array<int[]>::value: "
<< std::is_array<int[]>::value << std::endl;
std::cout << "std::is_array<int[3]>::value: "
<< std::is_array<int[3]>::value << std::endl;
std::cout << std::endl;
std::cout << "std::is_enum<A>::value: "
<< std::is_enum<A>::value << std::endl;
std::cout << "std::is_enum<E>::value: "
<< std::is_enum<E>::value << std::endl;
std::cout << "std::is_enum<Ec>::value: "
<< std::is_enum<Ec>::value << std::endl;
std::cout << "std::is_enum<int>::value: "
<< std::is_enum<int>::value << std::endl;
std::cout << std::endl;
return 0;
}