內(nèi)存中的儲(chǔ)存形式(IEEE-745)
Address 3 2 1 0
Content SEEEEEEE EBBBBBBB BBBBBBBB BBBBBBBB
其中的字母分別代表:
- S(Significand):1 - 正負(fù)號(hào)

- E(Exponent):8 - 指數(shù)部分
- B(Base):23 - 底數(shù)部分
這樣, 整個(gè)浮點(diǎn)數(shù)表示起來(lái)就是:

N進(jìn)制的小數(shù)
看到10進(jìn)制的小數(shù), 小數(shù)點(diǎn)是用來(lái)分隔指數(shù)正負(fù)位的:


推廣到N進(jìn)制, 形式是完全相同的, 這里用二進(jìn)制做一個(gè)例子:




構(gòu)造一個(gè)浮點(diǎn)數(shù)
以12.625為例子. 首先我們推算一下它的二進(jìn)制形式是什么. 如我們所知, 整數(shù)部分和小數(shù)部分的位置是恒定不變的, 因?yàn)樗鼈兪欠裥∮?這個(gè)性質(zhì), 無(wú)論在什么進(jìn)制之下都不會(huì)改變. 首先算整數(shù)部分:





小數(shù)部分(不知道是否注意到, 小數(shù)部分只有是2^n的和才有可能被表示成不循環(huán)小數(shù). 諸如0.7, 0.3都是二進(jìn)制的無(wú)限循環(huán)小數(shù)):




這樣, 我們得到了一個(gè)二進(jìn)位的小數(shù)1100.101, 并且化成IEEE-745標(biāo)準(zhǔn)形式:

Address 3 2 1 0
Content SEEEEEEE EBBBBBBB BBBBBBBB BBBBBBBB
Value 01000001 01001010 00000000 00000000
Hex 41 4A 00 00
現(xiàn)在我們得到了一個(gè)整數(shù)0x414A0000, 把它輸出出來(lái)看看是多少:
$ cat test.c
#include <stdio.h>
int main()
{
union {
unsigned long u;
float f;
} u;
u.u = 0x414a0000;
printf("%f\n", u.f);
return 0;
}
$ ./test
12.625000