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_MIN
SHRT_MIN
INT_MIN
LONG_MIN
LLONG_MIN




(C++11)
各为 signed charshortintlonglong long 的最小值
(宏常量)
SCHAR_MAX
SHRT_MAX
INT_MAX
LONG_MAX
LLONG_MAX




(C++11)
各为 signed charshortintlonglong long 的最大值
(宏常量)
UCHAR_MAX
USHRT_MAX
UINT_MAX
ULONG_MAX
ULLONG_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 转换到十进制表示,再转换回 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
各为 floatdoublelong double 的最小正规正值
(宏常量)
FLT_TRUE_MIN
DBL_TRUE_MIN
LDBL_TRUE_MIN
(C++17)
各为 floatdoublelong double 的最小正值
(宏常量)
FLT_MAX
DBL_MAX
LDBL_MAX
各为 floatdoublelong double 的最大值
(宏常量)
FLT_EPSILON
DBL_EPSILON
LDBL_EPSILON
各为 1.0 和下个 floatdoublelong 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 的数字能无损精度地表示成 floatdoublelong double 的位数
(宏常量)
FLT_MIN_EXP
DBL_MIN_EXP
LDBL_MIN_EXP
满足条件的最小负整数, FLT_RADIX 的该数减一次幂分别是正规的 floatdoublelong double
(宏常量)
FLT_MIN_10_EXP
DBL_MIN_10_EXP
LDBL_MIN_10_EXP
满足条件的最小负整数, 10 的该数减一此幂分别是正规的 floatdoublelong double
(宏常量)
FLT_MAX_EXP
DBL_MAX_EXP
LDBL_MAX_EXP
各为满足要求的最大正整数, FLT_RADIX 的该数加一次幂分别能为正规的 floatdoublelong double
(宏常量)
FLT_MAX_10_EXP
DBL_MAX_10_EXP
LDBL_MAX_10_EXP
各为满足要求的最大正整数, 10 的该数加一次幂分别能为正规的 floatdoublelong double
(宏常量)
浮点算术的默认舍入模式
(宏常量)
指定进行所有算术运算所用的精度
(宏常量)
FLT_HAS_SUBNORM
DBL_HAS_SUBNORM
LDBL_HAS_SUBNORM
(C++17)
指明类型是否支持非正规数值: -1 为不确定, 0 为不支持, 1 为支持。
(宏常量)

参阅

版本历史

  • (当前 | 先前 2017年2月5日 (日) 04:32Fruderica讨论 | 贡献. . (2,413字节) (-5,168). . (撤销)
  • 当前 | 先前 2013年7月2日 (二) 11:38P12bot讨论 | 贡献 . . (7,581字节) (-180). . (Use {{lc}}. Update links. Various fixes.) (撤销)
  • 当前 | 先前 2012年11月2日 (五) 17:19P12bot讨论 | 贡献 . . (7,761字节) (+175). . (r2.7.3) (机器人添加:de, en, es, fr, ja, pt, ru) (撤销)
  • 当前 | 先前 2012年10月27日 (六) 11:35P12讨论 | 贡献 . . (7,586字节) (0). . (1个修订: Translate from the English version) (撤销)
  • 当前 | 先前 2012年10月26日 (五) 06:00TranslationBot讨论 | 贡献. . (7,586字节) (-202). . (Translated from the English version using Google Translate) (撤销)
  • 当前 | 先前 2012年10月26日 (五) 03:33P12讨论 | 贡献 . . (7,788字节) (0). . (1个修订: Translate from the English version) (撤销)
  • 当前 | 先前) 2012年10月25日 (四) 12:00TranslationBot讨论 | 贡献. . (7,788字节) (+7,788). . (Translated from the English version using Google Translate)