在C语言中,float.h 是一个标准库头文件,它定义了一系列与浮点数相关的、依赖于具体实现的宏常量。这些常量提供了有关平台支持的浮点类型(如 float、double 和 long double)的精度和范围信息,这对于编写跨平台兼容或需要了解浮点数据精确特性的程序非常重要。

以下是一些在 float.h 中定义的宏:

一、最大值和最小值

1、FLT_MAX , DBL_MAX , LDBL_MAX : 分别表示 float、double 和 longdouble 类型的最大正值。

2、FLT_MIN , DBL_MIN , LDBL_MIN : 分别表示对应类型的最小正非零值(即最接近0的正数)。

二、精度

1、FLT_DIG , DBL_DIG , LDBL_DIG : 表示分别用 float、double 和 long double 类型能够精确表示的十进制数字的个数。

三、指数范围

1、FLT_MIN_10_EXP , DBL_MIN_10_EXP , LDBL_MIN_10_EXP : 类型能表示的最小负指数(以10为基数)。

2、FLT_MAX_10_EXP , DBL_MAX_10_EXP , LDBL_MAX_10_EXP : 类型能表示的最大正指数(以10为基数)。

3、对应的二进制指数也有类似定义,如 FLT_MIN_EXP, FLT_MAX_EXP 等。

四、其他属性

1、FLT_EPSILON , DBL_EPSILON , LDBL_EPSILON : 表示类型能够表示的最小正数,使得1.0加这个数后结果不等于1.0,也就是机器精度。

2、FLT_ROUNDS : 表示浮点数运算的舍入模式(通常取值可以是 -1, 0, 1, 2, 3,分别代表不确定、向零舍入、向最近偶数舍入、向正无穷舍入、向负无穷舍入)。

通过查询 float.h 中提供的这些宏,可以编写更为精确和健壮的浮点数计算代码,确保它们在不同平台上具有预期的行为。