Namespaces
Variants

std:: is_integral

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
(C++11) ( DR* )
(C++11)
(C++11)
is_integral
(C++11)
Type properties
(C++11)
(C++11)
(C++14)
(C++11) (deprecated in C++26)
(C++11) ( until C++20* )
(C++11) (deprecated in C++20)
(C++11)
Type trait constants
Metafunctions
(C++17)
Supported operations
Relationships and property queries
Type modifications
Type transformations
(C++11) (deprecated in C++23)
(C++11) (deprecated in C++23)
(C++11)
(C++11) ( until C++20* ) (C++17)

Compile-time rational arithmetic
Compile-time integer sequences
定义于头文件 <type_traits>
template < class T >
struct is_integral ;
(C++11 起)

std::is_integral 是一个 UnaryTypeTrait

检查 T 是否为 整数类型 。提供成员常量 value ,当 T 是类型 bool char char8_t (C++20 起) char16_t char32_t wchar_t short int long long long ,或任何实现定义的扩展整数类型(包括所有有符号、无符号及 cv 限定变体)时,该常量值为 true 。否则 value 等于 false

如果程序为 std::is_integral std::is_integral_v 添加特化,则行为是未定义的。

目录

模板参数

T - 待检查的类型

辅助变量模板

template < class T >
constexpr bool is_integral_v = is_integral < T > :: value ;
(C++17 起)

继承自 std:: integral_constant

成员常量

value
[static]
T 为整数类型则为 true ,否则为 false
(公开静态成员常量)

成员函数

operator bool
转换对象为 bool ,返回 value
(公开成员函数)
operator()
(C++14)
返回 value
(公开成员函数)

成员类型

类型 定义
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 <type_traits>
static_assert
(
    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
);
class A {};
static_assert(std::is_integral_v<A> == false);
struct B { int x:4; };
static_assert(std::is_integral_v<B> == false);
using BF = decltype(B::x); // 位域的类型
static_assert(std::is_integral_v<BF> == true);
enum E : int {};
static_assert(std::is_integral_v<E> == false);
template <class T>
constexpr T same(T i)
{
    static_assert(std::is_integral<T>::value, "Integral required.");
    return i;
}
static_assert(same('"') == 042);
int main() {}

参见

(C++20)
指定类型为整数类型
(概念)
[static]
标识整数类型
( std::numeric_limits<T> 的公开静态成员常量)
检查类型是否为浮点类型
(类模板)
检查类型是否为算术类型
(类模板)
(C++11)
检查类型是否为枚举类型
(类模板)