C++ 参考手册

参阅 std::numeric_limits 接口。

定义于头文件 <cstdint>
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 类型对象的最大值
(宏常量)

整数类型极限

定义于头文件 <climits>
CHAR_BIT
字节的位数
(宏常量)
MB_LEN_MAX
多字节字符的最大字节数
(宏常量)
CHAR_MIN
char 的最小值
(宏常量)
CHAR_MAX
char 的最大值
(宏常量)
SCHAR_MINSHRT_MININT_MINLONG_MINLLONG_MIN
(C++11)
分别为 signed charshortintlonglong long 的最小值
(宏常量)
SCHAR_MAXSHRT_MAXINT_MAXLONG_MAXLLONG_MAX
(C++11)
分别为 signed charshortintlonglong long 的最大值
(宏常量)
UCHAR_MAXUSHRT_MAXUINT_MAXULONG_MAXULLONG_MAX
(C++11)
分别为 unsigned charunsigned shortunsigned int
unsigned longunsigned long long 的最大值
(宏常量)

注意:这些常量,除了 CHAR_BITMB_LEN_MAX ,都要求其类型匹配整数提升的结果,一如应用于它们所描述的类型的对象: CHAR_MAX 可能拥有类型 intunsigned int ,但决非 char 。同样地 USHRT_MAX 可能不拥有无符号类型:其类型可能是 int

浮点类型极限

定义于头文件 <cfloat>
FLT_RADIX
所有三种浮点类型的表示所用的基数(整数底)
(宏常量)
DECIMAL_DIG
(C++11)
long double 转换到至少有 DECIMAL_DIG 位数字的十进制表示,再转换回 long double 为恒等转换:这是序列化/反序列化 long double 所要求的十进制精度(参阅 std::numeric_limits::max_digits10
(宏常量)
FLT_DECIMAL_DIGDBL_DECIMAL_DIGLDBL_DECIMAL_DIG
(C++17)
float/double/long double 转换到至少有 FLT_DECIMAL_DIG/DBL_DECIMAL_DIG/LDBL_DECIMAL_DIG 位数字的十进制,再转换回原类型为恒等转换:这是序列化/反序列化浮点值所要求的十进制精度(参阅 std::numeric_limits::max_digits10)。分别定义为至少 6、10 和 10,对于 IEEE float 为 9,对于 IEEE double 为 17。
(宏常量)
FLT_MINDBL_MINLDBL_MIN
分别为 floatdoublelong double 的最小规格化正数值
(宏常量)
FLT_TRUE_MINDBL_TRUE_MINLDBL_TRUE_MIN
(C++17)
分别为 floatdoublelong double 的最小正数值
(宏常量)
FLT_MAXDBL_MAXLDBL_MAX
分别为 floatdoublelong double 的最大有限值
(宏常量)
FLT_EPSILONDBL_EPSILONLDBL_EPSILON
分别为 1.0floatdoublelong double 的下一个可表示值之差
(宏常量)
FLT_DIGDBL_DIGLDBL_DIG
保证能在文本→ float/double/long double →文本的往返转换中保留而不会因舍入或溢出发生改变的的十进制位数(解释参阅 std::numeric_limits::digits10
(宏常量)
FLT_MANT_DIGDBL_MANT_DIGLDBL_MANT_DIG
分别为能无精度损失地表示成 floatdoublelong double 的基数 FLT_RADIX 的数字位数
(宏常量)
FLT_MIN_EXPDBL_MIN_EXPLDBL_MIN_EXP
分别为能够使FLT_RADIX 的该整数减一次幂为规格化的 floatdoublelong double 的最小负整数
(宏常量)
FLT_MIN_10_EXPDBL_MIN_10_EXPLDBL_MIN_10_EXP
分别为能够使 10 的该整数减一次幂为规格化的 floatdoublelong double 的最小负整数
(宏常量)
FLT_MAX_EXPDBL_MAX_EXPLDBL_MAX_EXP
分别为能够使 FLT_RADIX 的该整数减一次幂为可表示的有限的 floatdoublelong double 的最大正整数
(宏常量)
FLT_MAX_10_EXPDBL_MAX_10_EXPLDBL_MAX_10_EXP
分别为能够使 10 的该整数减一次幂为可表示的有限的 floatdoublelong double 的最大正整数
(宏常量)
浮点算术的默认舍入模式
(宏常量)
指定进行所有算术运算所用的精度
(宏常量)
FLT_HAS_SUBNORMDBL_HAS_SUBNORMLDBL_HAS_SUBNORM
(C++17)
指明类型是否支持非正规数值:-1 为不确定,0 为不支持,1 为支持。
(宏常量)

参阅