std::is_floating_point
来自cppreference.com
在标头 <type_traits> 定义 | ||
template<class T > struct is_floating_point; | (C++11 起) | |
std::is_floating_point
是一元类型特征(UnaryTypeTrait) 。
检查 T
是否为浮点数类型。如果 T
为类型 float、double、longdouble,或者任何扩展浮点数类型(std::float16_t、std::float32_t、std::float64_t、std::float128_t 或 std::bfloat16_t)(C++23 起),包括任何 cv 限定变体,那么提供的成员常量 value 等于 true。否则,value 等于 false。
如果程序添加了 std::is_floating_point
或 std::is_floating_point_v
的特化,那么行为未定义。
目录 |
[编辑]模板形参
T | - | 要检查的类型 |
[编辑]辅助变量模板
template<class T > constexprbool is_floating_point_v = is_floating_point<T>::value; | (C++17 起) | |
继承自 std::integral_constant
成员常量
value [静态] | 如果 T 为(可能 cv 限定的)浮点数类型那么是 true,否则是 false(公开静态成员常量) |
成员函数
operator bool | 将对象转换到 bool,返回 value (公开成员函数) |
operator() (C++14) | 返回 value (公开成员函数) |
成员类型
类型 | 定义 |
value_type | bool |
type | std::integral_constant<bool, value> |
[编辑]可能的实现
template<class T>struct is_floating_point :std::integral_constant<bool, // 注:标准浮点数类型std::is_same<float, typenamestd::remove_cv<T>::type>::value||std::is_same<double, typenamestd::remove_cv<T>::type>::value||std::is_same<longdouble, typenamestd::remove_cv<T>::type>::value// 注:扩展浮点数类型(C++23,若支持)||std::is_same<std::float16_t, typenamestd::remove_cv<T>::type>::value||std::is_same<std::float32_t, typenamestd::remove_cv<T>::type>::value||std::is_same<std::float64_t, typenamestd::remove_cv<T>::type>::value||std::is_same<std::float128_t, typenamestd::remove_cv<T>::type>::value||std::is_same<std::bfloat16_t, typenamestd::remove_cv<T>::type>::value>{}; |
[编辑]示例
运行此代码
#include <type_traits> class A {}; static_assert(!std::is_floating_point_v<A>); static_assert(std::is_floating_point_v<float>); static_assert(!std::is_floating_point_v<float&>); static_assert(std::is_floating_point_v<double>); static_assert(!std::is_floating_point_v<double&>); static_assert(!std::is_floating_point_v<int>); int main(){}
[编辑]参阅
[静态] | 鉴别 IEC 559/IEEE 754 浮点数类型 ( std::numeric_limits<T> 的公开静态成员常量) |
(C++11) | 检查类型是否为整数类型 (类模板) |
(C++11) | 检查类型是否为算术类型 (类模板) |
(C++20) | 指定类型为浮点数类型 (概念) |