std::is_floating_point
From cppreference.com
Template:ddcl list begin <tr class="t-dsc-header">
<td>Defined in header
</td>
<type_traits>
<td></td> <td></td> </tr> <tr class="t-dcl ">
<td >template< class T >
struct is_floating_point;
</td>
struct is_floating_point;
<td class="t-dcl-nopad"> </td> <td > (since C++11) </td> </tr> Template:ddcl list end
If T
is a floating-point type (float, double, long double, including any cv-qualified variants), provides the member constant value
equal true. For any other type, value
is false.
Contents |
Inherited from std::integral_constant
Member constants
value [static] |
true if T is a floating-point type , false otherwise (public static member constant) |
Member functions
operator bool |
converts the object to bool, returns value (public member function) |
operator() (C++14) |
returns value (public member function) |
Member types
Type | Definition |
value_type
|
bool |
type
|
std::integral_constant<bool, value> |
Possible implementation
Example
Run this code
#include <iostream> #include <type_traits> class A {}; int main() { std::cout << std::boolalpha; std::cout << std::is_floating_point<A>::value << '\n'; std::cout << std::is_floating_point<float>::value << '\n'; std::cout << std::is_floating_point<int>::value << '\n'; }
Output:
false true false
See also
[static] |
identifies the IEC 559/IEEE 754 floating-point types (public static member constant of std::numeric_limits<T> )
|
(C++11) |
checks if a type is an integral type (class template) |
(C++11) |
checks if a type is an arithmetic type (class template) |