std::is_integral
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <type_traits>
|
||
template< class T > struct is_integral; |
(начиная с C++11) | |
std::is_integral является UnaryTypeTrait.
Проверяет, является ли T целочисленным типом. Предоставляет константу-элемент value, которая равна true, если T имеет тип bool, char, char8_t (начиная с C++20), char16_t, char32_t, wchar_t, short, int, long, long long или любого из определённых реализацией расширенных целочисленных типов, включая любые варианты со знаком, без знака и cv-квалификацией. Иначе value равна false.
Поведение программы, добавляющей специализации для std::is_integral или std::is_integral_v (начиная с C++17) не определено.
Параметры шаблона
| T | — | тип для проверки |
Шаблон вспомогательной переменной
<tbody> </tbody> template< class T > inline constexpr bool is_integral_v = is_integral<T>::value; |
(начиная с C++17) | |
Унаследован от std::integral_constant
Константы элементы
value [static] |
true, если T является целочисленным типом, false иначе (public static константа-элемент) |
Функции-элементы
operator bool |
преобразует объект в bool, возвращает value (public функция-элемент) |
operator() (C++14) |
возвращает value (public функция-элемент) |
Типы элементы
| Тип | Определение |
value_type
|
bool
|
type
|
std::integral_constant<bool, value>
|
Возможная реализация
// Примечание: в этой реализации используются средства C++20
template< class T >
struct is_integral : std::bool_constant<
requires (T t, T* p, void (*f)(T)) // Параметр T* исключает ссылочные типы
{
reinterpret_cast<T>(t); // Исключает классовые типы
f(0); // Исключает типы перечислений
p + t; // Исключает всё, что ещё не исключено, кроме интегральных типов
}> {};
|
Пример
Запустить этот код
#include <iostream>
#include <iomanip>
#include <type_traits>
class A {};
struct B { int x:4{2}; };
using BF = decltype(B::x); // тип битового поля
enum E : int {};
template <class T>
T f(T i)
{
static_assert(std::is_integral<T>::value, "Требуется целочисленный тип.");
return i;
}
#define SHOW(...) \
std::cout << std::setw(29) << #__VA_ARGS__ << " == " << __VA_ARGS__ << '\n'
int main()
{
std::cout << std::boolalpha;
SHOW( std::is_integral<A>::value );
SHOW( std::is_integral_v<E> );
SHOW( std::is_integral_v<float> );
SHOW( std::is_integral_v<int*> );
SHOW( std::is_integral_v<int> );
SHOW( std::is_integral_v<const int> );
SHOW( std::is_integral_v<bool> );
SHOW( std::is_integral_v<char> );
SHOW( std::is_integral_v<BF> );
SHOW( f(123) );
}
Вывод:
std::is_integral<A>::value == false
std::is_integral_v<E> == false
std::is_integral_v<float> == false
std::is_integral_v<int*> == false
std::is_integral_v<int> == true
std::is_integral_v<const int> == true
std::is_integral_v<bool> == true
std::is_integral_v<char> == true
std::is_integral_v<BF> == true
f(123) == 123
Смотрите также
(C++20) |
указывает, что тип является целым типом (концепт) |
[static] |
определяет целочисленные типы (public static константа-элемент std::numeric_limits)
|
(C++11) |
проверяет, является ли тип типом с плавающей запятой (шаблон класса) |
(C++11) |
проверяет, является ли тип арифметическим типом (шаблон класса) |
(C++11) |
проверяет, является ли тип типом перечисления (шаблон класса) |