标准库标头 <cstdint> (C++11)

来自cppreference.com
< cpp‎ | header


 
 
标准库标头
语言支持
<cfloat>
<cstdint> (C++11)
<stdfloat> (C++23)
<new>
<typeinfo>
概念
<concepts> (C++20)
诊断
<system_error> (C++11)

内存管理
<memory_resource> (C++17)  
元编程
<type_traits> (C++11)
<ratio> (C++11)
通用工具
<utility>
<tuple> (C++11)
<optional> (C++17)
<variant> (C++17)
<any> (C++17)
<debugging> (C++26)
<expected> (C++23)
<bitset>
<charconv> (C++17)
<format> (C++20)
<bit> (C++20)

字符串
<cuchar> (C++11)

容器
<flat_set> (C++23)
<span> (C++20)
<mdspan> (C++23)
<inplace_vector> (C++26)
迭代器
<iterator>
范围
<ranges> (C++20)
<generator> (C++23)
算法
数值
<cfenv> (C++11)
<complex>
<cmath>
<linalg> (C++26)
<numbers> (C++20)

日期时间
<chrono> (C++11)
本地化
<codecvt> (C++11/17/26*)
<text_encoding> (C++26)
输入/输出
<filesystem> (C++17)
<cstdio>
<cinttypes> (C++11)
<strstream> (C++98/26*)
正则表达式
<regex> (C++11)
并发支持
<stop_token> (C++20)
<thread> (C++11)
<atomic> (C++11)
<rcu> (C++26)
<stdatomic.h> (C++23)
<mutex> (C++11)
<shared_mutex> (C++14)

<condition_variable> (C++11)  
<semaphore> (C++20)
<latch> (C++20)

<barrier> (C++20)
<future> (C++11)
<hazard_pointer> (C++26)

C 兼容
<cstdbool> (C++11/17/20*)  
<ccomplex> (C++11/17/20*)
<ctgmath> (C++11/17/20*)

<cstdalign> (C++11/17/20*)

<ciso646> (C++20 前)

 

此标头原作为 <stdint.h> 存在于 C 标准库。

此头文件是类型支持库的一部分,提供定宽整数类型和部分 C 数值极限接口

类型

int8_tint16_tint32_tint64_t
(可选)
分别是宽度正好是 8、16、32 和 64 位的有符号整数类型
无填充位并对负值使用补码
(当且仅当实现直接支持该类型时才会提供)
(typedef)
int_fast8_tint_fast16_tint_fast32_tint_fast64_t
分别是宽度至少有 8、16、32 和 64 位的最快的有符号整数类型
(typedef)
int_least8_tint_least16_tint_least32_tint_least64_t
分别是宽度至少有 8、16、32 和 64 位的最小的有符号整数类型
(typedef)
intmax_t
最大宽度的有符号整数类型
(typedef)
intptr_t
(可选)
足以保有指向 void 的指针的有符号整数类型
(typedef)
uint8_tuint16_tuint32_tuint64_t
(可选)
分别是宽度正好是 8、16、32 和 64 位的无符号整数类型
(当且仅当实现直接支持该类型时才会提供)
(typedef)
uint_fast8_tuint_fast16_tuint_fast32_tuint_fast64_t
分别是宽度至少有 8、16、32 和 64 位的最快的无符号整数类型
(typedef)
uint_least8_tuint_least16_tuint_least32_tuint_least64_t
分别是宽度至少有 8、16、32 和 64 位的最小的无符号整数类型
(typedef)
uintmax_t
最大宽度的无符号整数类型
(typedef)
uintptr_t
(可选)
足以保有指向 void 的指针的无符号整数类型
(typedef)

有符号整数:最小值
INT8_MININT16_MININT32_MININT64_MIN
(可选)
分别是 std::int8_tstd::int16_tstd::int32_tstd::int64_t 的最小值
(宏常量)
INT_FAST8_MININT_FAST16_MININT_FAST32_MININT_FAST64_MIN
分别是 std::int_fast8_tstd::int_fast16_tstd::int_fast32_tstd::int_fast64_t 的最小值
(宏常量)
INT_LEAST8_MININT_LEAST16_MININT_LEAST32_MININT_LEAST64_MIN
分别是 std::int_least8_tstd::int_least16_tstd::int_least32_tstd::int_least64_t 的最小值
(宏常量)
INTPTR_MIN
(可选)
std::intptr_t 的最小值
(宏常量)
INTMAX_MIN
std::intmax_t 的最小值
(宏常量)
有符号整数:最大值
INT8_MAXINT16_MAXINT32_MAXINT64_MAX
(可选)
分别是 std::int8_tstd::int16_tstd::int32_tstd::int64_t 的最大值
(宏常量)
INT_FAST8_MAXINT_FAST16_MAXINT_FAST32_MAXINT_FAST64_MAX
分别是 std::int_fast8_tstd::int_fast16_tstd::int_fast32_tstd::int_fast64_t 的最大值
(宏常量)
INT_LEAST8_MAXINT_LEAST16_MAXINT_LEAST32_MAXINT_LEAST64_MAX
分别是 std::int_least8_tstd::int_least16_tstd::int_least32_tstd::int_least64_t 的最大值
(宏常量)
INTPTR_MAX
(可选)
std::intptr_t 的最大值
(宏常量)
INTMAX_MAX
std::intmax_t 的最大值
(宏常量)
无符号整数:最大值
UINT8_MAXUINT16_MAXUINT32_MAXUINT64_MAX
(可选)
分别是 std::uint8_tstd::uint16_tstd::uint32_tstd::uint64_t 的最大值
(宏常量)
UINT_FAST8_MAXUINT_FAST16_MAXUINT_FAST32_MAXUINT_FAST64_MAX
分别是 std::uint_fast8_tstd::uint_fast16_tstd::uint_fast32_tstd::uint_fast64_t 的最大值
(宏常量)
UINT_LEAST8_MAXUINT_LEAST16_MAXUINT_LEAST32_MAXUINT_LEAST64_MAX
分别是 std::uint_least8_tstd::uint_least16_tstd::uint_least32_tstd::uint_least64_t 的最大值
(宏常量)
UINTPTR_MAX
(可选)
std::uintptr_t 的最大值
(宏常量)
UINTMAX_MAX
std::uintmax_t 的最大值
(宏常量)
其他整数类型的极限
PTRDIFF_MIN
(C++11)
std::ptrdiff_t 的最小值
(宏常量)
PTRDIFF_MAX
(C++11)
std::ptrdiff_t 的最大值
(宏常量)
SIZE_MAX
(C++11)
std::size_t 的最大值
(宏常量)
SIG_ATOMIC_MIN
(C++11)
std::sig_atomic_t 的最小值
(宏常量)
SIG_ATOMIC_MAX
(C++11)
std::sig_atomic_t 的最大值
(宏常量)
WCHAR_MIN
(C++11)
wchar_t 的最小值
(宏常量)
WCHAR_MAX
(C++11)
wchar_t 的最大值
(宏常量)
WINT_MIN
(C++11)
std::wint_t 的最小值
(宏常量)
WINT_MAX
(C++11)
std::wint_t 的最大值
(宏常量)
整数常量的函数宏
INT8_CINT16_CINT32_CINT64_C
展开成拥有它的实参所指定的值且类型分别是 std::int_least8_tstd::int_least16_tstd::int_least32_tstd::int_least64_t提升类型的整数常量表达式
(宏函数)
INTMAX_C
展开成拥有它的实参所指定的值且类型是 std::intmax_t 的整数常量表达式
(宏函数)
UINT8_CUINT16_CUINT32_CUINT64_C
展开成拥有它的实参所指定的值且类型分别是 std::uint_least8_tstd::uint_least16_tstd::uint_least32_tstd::uint_least64_t提升类型的整数常量表达式
(宏函数)
UINTMAX_C
展开成拥有它的实参所指定的值且类型是 std::uintmax_t 的整数常量表达式
(宏函数)

概要

namespace std {
  using int8_t         = /* 有符号整数类型 */; // 可选
  using int16_t        = /* 有符号整数类型 */; // 可选
  using int32_t        = /* 有符号整数类型 */; // 可选
  using int64_t        = /* 有符号整数类型 */; // 可选
  using intN_t         = /* 见描述 */;        // 可选,见描述
 
  using int_fast8_t    = /* 有符号整数类型 */;
  using int_fast16_t   = /* 有符号整数类型 */;
  using int_fast32_t   = /* 有符号整数类型 */;
  using int_fast64_t   = /* 有符号整数类型 */;
  using int_fastN_t    = /* 见描述 */;        // 可选,见描述
 
  using int_least8_t   = /* 有符号整数类型 */;
  using int_least16_t  = /* 有符号整数类型 */;
  using int_least32_t  = /* 有符号整数类型 */;
  using int_least64_t  = /* 有符号整数类型 */;
  using int_leastN_t   = /* 见描述 */;        // 可选,见描述
 
  using intmax_t       = /* 有符号整数类型 */;
  using intptr_t       = /* 有符号整数类型 */; // 可选
 
  using uint8_t        = /* 无符号整数类型 */; // 可选
  using uint16_t       = /* 无符号整数类型 */; // 可选
  using uint32_t       = /* 无符号整数类型 */; // 可选
  using uint64_t       = /* 无符号整数类型 */; // 可选
  using uintN_t        = /* 见描述 */;        // 可选,见描述
 
  using uint_fast8_t   = /* 无符号整数类型 */;
  using uint_fast16_t  = /* 无符号整数类型 */;
  using uint_fast32_t  = /* 无符号整数类型 */;
  using uint_fast64_t  = /* 无符号整数类型 */;
  using uint_fastN_t   = /* 见描述 */;        // 可选,见描述
 
  using uint_least8_t  = /* 无符号整数类型 */;
  using uint_least16_t = /* 无符号整数类型 */;
  using uint_least32_t = /* 无符号整数类型 */;
  using uint_least64_t = /* 无符号整数类型 */;
  using uint_leastN_t  = /* 见描述 */;        // 可选,见描述
 
  using uintmax_t      = /* 无符号整数类型 */;
  using uintptr_t      = /* 无符号整数类型 */; // 可选
}
 
#define INTN_MIN         /* 见描述 */
#define INTN_MAX         /* 见描述 */
#define UINTN_MAX        /* 见描述 */
 
#define INT_FASTN_MIN    /* 见描述 */
#define INT_FASTN_MAX    /* 见描述 */
#define UINT_FASTN_MAX   /* 见描述 */
 
#define INT_LEASTN_MIN   /* 见描述 */
#define INT_LEASTN_MAX   /* 见描述 */
#define UINT_LEASTN_MAX  /* 见描述 */
 
#define INTMAX_MIN       /* 见描述 */
#define INTMAX_MAX       /* 见描述 */
#define UINTMAX_MAX      /* 见描述 */
 
#define INTPTR_MIN       /* 见描述 */         // 可选
#define INTPTR_MAX       /* 见描述 */         // 可选
#define UINTPTR_MAX      /* 见描述 */         // 可选
 
#define PTRDIFF_MIN      /* 见描述 */
#define PTRDIFF_MAX      /* 见描述 */
#define SIZE_MAX         /* 见描述 */
 
#define SIG_ATOMIC_MIN   /* 见描述 */
#define SIG_ATOMIC_MAX   /* 见描述 */
 
#define WCHAR_MIN        /* 见描述 */
#define WCHAR_MAX        /* 见描述 */
 
#define WINT_MIN         /* 见描述 */
#define WINT_MAX         /* 见描述 */
 
#define INTN_C(value)    /* 见描述 */
#define UINTN_C(value)   /* 见描述 */
#define INTMAX_C(value)  /* 见描述 */
#define UINTMAX_C(value) /* 见描述 */