std::is_floating_point
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <type_traits>
|
||
template< class T > struct is_floating_point; |
(начиная с C++11) | |
std::is_floating_point является UnaryTypeTrait.
Проверяет, является ли T типом с плавающей запятой. Предоставляет константу-элемент value, которая равна true, если T имеет тип float, double, long double или любого расширенного типа с плавающей запятой (std::float16_t, std::float32_t, std::float64_t, std::float128_t или std::bfloat16_t) (начиная с C++23), включая любые варианты с cv-квалификацией. Иначе value равна false.
Поведение программы, добавляющей специализации для std::is_floating_point или std::is_floating_point_v (начиная с C++17) не определено.
Параметры шаблона
| T | — | тип для проверки |
Шаблон вспомогательной переменной
<tbody> </tbody> template< class T > inline constexpr bool is_floating_point_v = is_floating_point<T>::value; |
(начиная с C++17) | |
Унаследован от std::integral_constant
Константы элементы
value [static] |
true, если T является типом с плавающей запятой (возможно, cv-квалифицированный), false иначе (public static константа-элемент) |
Функции-элементы
operator bool |
преобразует объект в bool, возвращает value (public функция-элемент) |
operator() (C++14) |
возвращает value (public функция-элемент) |
Типы элементы
| Тип | Определение |
value_type
|
bool
|
type
|
std::integral_constant<bool, value>
|
Возможная реализация
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
// Примечание: расширенные типы с плавающей запятой (C++23, если поддерживается)
|| std::is_same<std::float16_t, typename std::remove_cv<T>::type>::value
|| std::is_same<std::float32_t, typename std::remove_cv<T>::type>::value
|| std::is_same<std::float64_t, typename std::remove_cv<T>::type>::value
|| std::is_same<std::float128_t, typename std::remove_cv<T>::type>::value
|| std::is_same<std::bfloat16_t, typename std::remove_cv<T>::type>::value
> {};
|
Пример
Запустить этот код
#include <iostream>
#include <type_traits>
class A {};
int main()
{
std::cout << std::boolalpha;
std::cout << " A: " << std::is_floating_point<A>::value << '\n';
std::cout << " float: " << std::is_floating_point<float>::value << '\n';
std::cout << " float&: " << std::is_floating_point<float&>::value << '\n';
std::cout << " double: " << std::is_floating_point<double>::value << '\n';
std::cout << "double&: " << std::is_floating_point<double&>::value << '\n';
std::cout << " int: " << std::is_floating_point<int>::value << '\n';
}
Вывод:
A: false
float: true
float&: false
double: true
double&: false
int: false
Смотрите также
[static] |
определяет типы с плавающей точкой IEC 559/IEEE 754 (public static константа-элемент std::numeric_limits)
|
(C++11) |
проверяет, является ли тип целочисленным типом (шаблон класса) |
(C++11) |
проверяет, является ли тип арифметическим типом (шаблон класса) |
(C++20) |
указывает, что тип, это число с плавающей точкой (концепт) |