另见 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_MIN
SHRT_MIN INT_MIN LONG_MIN LLONG_MIN (C++11) |
各为 signed char、 short、 int、 long 及 long long 的最小值 (宏常量) |
SCHAR_MAX
SHRT_MAX INT_MAX LONG_MAX LLONG_MAX (C++11) |
各为 signed char、 short、 int、 long 及 long long 的最大值 (宏常量) |
UCHAR_MAX
USHRT_MAX UINT_MAX ULONG_MAX ULLONG_MAX (C++11) |
各为 unsigned char、 unsigned short、 unsigned int、 unsigned long 及 unsigned long long 的最大值 (宏常量) |
注意:这些常量,除了 CHAR_BIT
和MB_LEN_MAX
,其类型都被要求匹配整数提升的结果,一如应用于它们所描述的类型的对象: CHAR_MAX
可能拥有类型 int 或 unsigned int ,但决非 char 。同样地 USHRT_MAX
可能不拥有无符号类型:其类型可能是 int 。
定义于头文件
<cfloat> |
|
FLT_RADIX
|
表示所有三种浮点类型的基底(整数底) (宏常量) |
DECIMAL_DIG
(C++11)
|
从 long double 转换到十进制表示,再转换回 long double 保证能为原数,该十进制表示至少有 DECIMAL_DIG 位数字:这是序列化/反序列化 long double 所要求的十进制精度(参阅 std::numeric_limits::max_digits10 ) (宏常量) |
FLT_DECIMAL_DIG
DBL_DECIMAL_DIG LDBL_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_MIN
DBL_MIN LDBL_MIN |
各为 float、 double 与 long double 的最小正规正值 (宏常量) |
FLT_TRUE_MIN
DBL_TRUE_MIN LDBL_TRUE_MIN (C++17)
|
各为 float、 double 与 long double 的最小正值 (宏常量) |
FLT_MAX
DBL_MAX LDBL_MAX |
各为 float、 double 与 long double 的最大值 (宏常量) |
FLT_EPSILON
DBL_EPSILON LDBL_EPSILON |
各为 1.0 和下个 float、 double 及 long double 可表示值之差 (宏常量) |
FLT_DIG
DBL_DIG LDBL_DIG |
保证能在文本→ float/double/long double →文本转换流程中保留的十进制位数,不计舍入或溢出(解释参阅 std::numeric_limits::digits10 ) (宏常量) |
FLT_MANT_DIG
DBL_MANT_DIG LDBL_MANT_DIG |
各为底 FLT_RADIX 的数字能无损精度地表示成 float、 double 及 long double 的位数 (宏常量) |
FLT_MIN_EXP
DBL_MIN_EXP LDBL_MIN_EXP |
满足条件的最小负整数, FLT_RADIX 的该数减一次幂分别是正规的 float、 double 与 long double (宏常量) |
FLT_MIN_10_EXP
DBL_MIN_10_EXP LDBL_MIN_10_EXP |
满足条件的最小负整数, 10 的该数减一此幂分别是正规的 float、 double 和 long double (宏常量) |
FLT_MAX_EXP
DBL_MAX_EXP LDBL_MAX_EXP |
各为满足要求的最大正整数, FLT_RADIX 的该数加一次幂分别能为正规的 float、 double 与 long double (宏常量) |
FLT_MAX_10_EXP
DBL_MAX_10_EXP LDBL_MAX_10_EXP |
各为满足要求的最大正整数, 10 的该数加一次幂分别能为正规的 float、 double 与 long double (宏常量) |
浮点算术的默认舍入模式 (宏常量) |
|
(C++11)
|
指定进行所有算术运算所用的精度 (宏常量) |
FLT_HAS_SUBNORM
DBL_HAS_SUBNORM LDBL_HAS_SUBNORM (C++17)
|
指明类型是否支持非正规数值: -1 为不确定, 0 为不支持, 1 为支持。 (宏常量) |