鍍金池/ 教程/ C/ C 標(biāo)準(zhǔn)庫 - < float.h >
C 輸入 & 輸出
C 標(biāo)準(zhǔn)庫 - < signal.h >
C 標(biāo)準(zhǔn)庫- < string.h >
C 循環(huán)
C 數(shù)據(jù)類型
C 字符串
C 標(biāo)準(zhǔn)庫 - < stdarg.h >
C 標(biāo)準(zhǔn)庫 - < math.h >
C 預(yù)處理器
C 存儲類
C 標(biāo)準(zhǔn)庫 - < locale.h >
C 指針
C 標(biāo)準(zhǔn)庫 - < assert.h >
C 結(jié)構(gòu)體
C 命令行參數(shù)
C 標(biāo)準(zhǔn)庫 - < ctype.h >
C 強(qiáng)制類型轉(zhuǎn)換
C 程序結(jié)構(gòu)
C typedef
C 遞歸
C 運(yùn)算符
C 環(huán)境設(shè)置
C 函數(shù)
C 位域
C 標(biāo)準(zhǔn)庫 - < stddef.h >
C 數(shù)組
C 標(biāo)準(zhǔn)庫 - < errno.h >
C 標(biāo)準(zhǔn)庫 -參考手冊
C 可變參數(shù)
C 變量
C 錯(cuò)誤處理
C 作用域規(guī)則
C 文件讀寫
C 內(nèi)存管理
C 基本語法
C 標(biāo)準(zhǔn)庫 - < stdio.h >
C 標(biāo)準(zhǔn)庫 - < time.h >
C 頭文件
C 判斷
C 標(biāo)準(zhǔn)庫 - < limits.h >
C 共用體
C 標(biāo)準(zhǔn)庫 - < setjmp.h >
C 常量
C 標(biāo)準(zhǔn)庫 - < float.h >
C 簡介
C 標(biāo)準(zhǔn)庫 - < stdlib.h >

C 標(biāo)準(zhǔn)庫 - < float.h >

簡介

C 標(biāo)準(zhǔn)庫的 float.h 頭文件包含了一組與浮點(diǎn)值相關(guān)的依賴于平臺的常量。這些常量是由 ANSI C 提出的,這讓程序更具有可移植性。在講解這些常量之前,最好先弄清楚浮點(diǎn)數(shù)是由下面四個(gè)元素組成的:

組件組件描述
S符號 ( +/- )
b指數(shù)表示的基數(shù),2 表示二進(jìn)制,10 表示十進(jìn)制,16 表示十六進(jìn)制,等等...
e指數(shù),一個(gè)介于最小值 emin 和最大值 emax 之間的整數(shù)。
p精度,基數(shù) b 的有效位數(shù)

基于以上 4 個(gè)組成部分,一個(gè)浮點(diǎn)數(shù)的值如下:

floating-point = ( S ) p x b<sup>e</sup>

或

floating-point = (+/-) precision x base<sup>exponent</sup>

庫宏

下面的值是特定實(shí)現(xiàn)的,且是通過 #define 指令來定義的,這些值都不得低于下邊所給出的值。請注意,所有的實(shí)例 FLT 是指類型 float,DBL 是指類型 double,LDBL 是指類型 long double。

描述
FLT_ROUNDS定義浮點(diǎn)加法的舍入模式,它可以是下列任何一個(gè)值:
  • -1 - 無法確定

  • 0 - 趨向于零

  • 1 - 去最近的值

  • 2 - 趨向于正無窮

  • 3 - 趨向于負(fù)無窮

FLT_RADIX 2這個(gè)宏定義了指數(shù)表示的基數(shù)?;鶖?shù) 2 表示二進(jìn)制,基數(shù) 10 表示十進(jìn)制,基數(shù) 16 表示十六進(jìn)制。

FLT_MANT_DIG

DBL_MANT_DIG

LDBL_MANT_DIG

這些宏定義了 FLT_RADIX 基數(shù)中的位數(shù)。

FLT_DIG 6

DBL_DIG 10

LDBL_DIG 10

這些宏定義了舍入后不會(huì)改變表示的十進(jìn)制數(shù)字的最大值(基數(shù) 10)。

FLT_MIN_EXP

DBL_MIN_EXP

LDBL_MIN_EXP

這些宏定義了基數(shù)為 FLT_RADIX 時(shí)的指數(shù)的最小負(fù)整數(shù)值。

FLT_MIN_10_EXP -37

DBL_MIN_10_EXP -37

LDBL_MIN_10_EXP -37

這些宏定義了基數(shù)為 10 時(shí)的指數(shù)的最小負(fù)整數(shù)值。

FLT_MAX_EXP

DBL_MAX_EXP

LDBL_MAX_EXP

這些宏定義了基數(shù)為 FLT_RADIX 時(shí)的指數(shù)的最大整數(shù)值。

FLT_MAX_10_EXP +37

DBL_MAX_10_EXP +37

LDBL_MAX_10_EXP +37

這些宏定義了基數(shù)為 10 時(shí)的指數(shù)的最大整數(shù)值。

FLT_MAX 1E+37

DBL_MAX 1E+37

LDBL_MAX 1E+37

這些宏定義最大的有限浮點(diǎn)值。

FLT_EPSILON 1E-5

DBL_EPSILON 1E-9

LDBL_EPSILON 1E-9

這些宏定義了可表示的最小有效數(shù)字。

FLT_MIN 1E-37

DBL_MIN 1E-37

LDBL_MIN 1E-37

這些宏定義了最小的浮點(diǎn)值。

實(shí)例

下面的實(shí)例演示了 float.h 文件中定義的一些常量的使用。

#include <stdio.h>
#include <float.h>

int main()
{
   printf("The maximum value of float = %.10e\n", FLT_MAX);
   printf("The minimum value of float = %.10e\n", FLT_MIN);

   printf("The number of digits in the number = %.10e\n", FLT_MANT_DIG);
}

讓我們編譯和運(yùn)行上面的程序,這將產(chǎn)生下列結(jié)果:

The maximum value of float = 3.4028234664e+38
The minimum value of float = 1.1754943508e-38
The number of digits in the number = 7.2996655210e-312