C 数值极限接口

来自cppreference.com
< cpp‎ | types
 
 
 
类型支持
基本类型
基础类型
定宽整数类型 (C++11)
数值极限
C 数值极限接口
运行时类型信息
类型特性
类型类别
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
类型属性
(C++11)
(C++11)
(C++11)
(C++14)
(C++11)
(C++11)(C++17中过时)
(C++11)
类型特性常量
元函数
(C++17)
受支持操作
关系与属性查询
(C++11)
(C++11)
(C++11)
(C++11)
类型修改
(C++11)
(C++11)
(C++11)
类型变换
(C++11)
(C++11)
(C++17)
(C++11)(C++17中过时)
(C++17)
 

另见 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 为支持。
(宏常量) [编辑]

[编辑] 参阅