标准库头文件 <cfloat>

来自cppreference.com
< cpp‎ | header
 
 
 

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

此头文件是类型支持库的一部分,特别是它是 C 数值极限接口的一部分。

[编辑]

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

[编辑] 概要

#define FLT_ROUNDS /*see definition*/
#define FLT_EVAL_METHOD /*see definition*/
#define FLT_HAS_SUBNORM /*see definition*/
#define DBL_HAS_SUBNORM /*see definition*/
#define LDBL_HAS_SUBNORM /*see definition*/
#define FLT_RADIX /*see definition*/
#define FLT_MANT_DIG /*see definition*/
#define DBL_MANT_DIG /*see definition*/
#define LDBL_MANT_DIG /*see definition*/
#define FLT_DECIMAL_DIG /*see definition*/
#define DBL_DECIMAL_DIG /*see definition*/
#define LDBL_DECIMAL_DIG /*see definition*/
#define DECIMAL_DIG /*see definition*/
#define FLT_DIG /*see definition*/
#define DBL_DIG /*see definition*/
#define LDBL_DIG /*see definition*/
#define FLT_MIN_EXP /*see definition*/
#define DBL_MIN_EXP /*see definition*/
#define LDBL_MIN_EXP /*see definition*/
#define FLT_MIN_10_EXP /*see definition*/
#define DBL_MIN_10_EXP /*see definition*/
#define LDBL_MIN_10_EXP /*see definition*/
#define FLT_MAX_EXP /*see definition*/
#define DBL_MAX_EXP /*see definition*/
#define LDBL_MAX_EXP /*see definition*/
#define FLT_MAX_10_EXP /*see definition*/
#define DBL_MAX_10_EXP /*see definition*/
#define LDBL_MAX_10_EXP /*see definition*/
#define FLT_MAX /*see definition*/
#define DBL_MAX /*see definition*/
#define LDBL_MAX /*see definition*/
#define FLT_EPSILON /*see definition*/
#define DBL_EPSILON /*see definition*/
#define LDBL_EPSILON /*see definition*/
#define FLT_MIN /*see definition*/
#define DBL_MIN /*see definition*/
#define LDBL_MIN /*see definition*/
#define FLT_TRUE_MIN /*see definition*/
#define DBL_TRUE_MIN /*see definition*/
#define LDBL_TRUE_MIN /*see definition*/