計算機內部浮點型資料的儲存

2021-06-07 03:34:18 字數 2075 閱讀 3347

c/c++浮點數在記憶體中的儲存方式

任何資料在記憶體中都是以二進位制的形式儲存的,例如乙個short型資料1156,其二進位制表示形式為00000100 10000100。則在intel cpu架構的系統中,存放方式為  10000100(低位址單元) 00000100(高位址單元),因為intel cpu的架構是小端模式。但是對於浮點數在記憶體是如何儲存的?目前所有的c/c++編譯器都是採用ieee所制定的標準浮點格式,即二進位制科學表示法。

在二進位制科學表示法中,s=m*2^n 主要由三部分構成:符號位+階碼(n)+尾數(m)。對於float型資料,其二進位制有32位,其中符號位1位,階碼8位,尾數23位;對於double型資料,其二進位制為64位,符號位1位,階碼11位,尾數52位。

31     30-23     22-0

float     符號位    階碼      尾數

63      62-52    51-0

double  符號位    階碼      尾數

符號位:0表示正,1表示負

階碼:這裡階碼採用移碼表示,對於float型資料其規定偏置量為127,階碼有正有負,對於8位二進位制,則其表示範圍為-128-127,double型規定為1023,其表示範圍為-1024-1023。比如對於float型資料,若階碼的真實值為2,則加上127後為129,其階碼表示形式為10000010

尾數:有效數字位,即部分二進位制位(小數點後面的二進位制位),因為規定m的整數部分恒為1,所以這個1就不進行儲存了。

下面舉例說明:

float型資料125.5轉換為標準浮點格式

125二進位制表示形式為1111101,小數部分表示為二進位制為 1,則125.5二進位制表示為1111101.1,由於規定尾數的整數部分恒為1,則表示為1.1111011*2^6,階碼為6,加上127為133,則表示為10000101,而對於尾數將整數部分1去掉,為1111011,在其後面補0使其位數達到23位,則為11110110000000000000000

則其二進位制表示形式為

0 10000101 11110110000000000000000,則在記憶體中存放方式為:

00000000   低位址

01000010   高位址

而反過來若要根據二進位制形式求算浮點數如0 10000101 11110110000000000000000

由於符號為為0,則為正數。階碼為133-127=6,尾數為11110110000000000000000,則其真實尾數為1.1111011。所以其大小為

1.1111011*2^6,將小數點右移6位,得到1111101.1,而1111101的十進位制為125,0.1的十進位制為1*2^(-1)=0.5,所以其大小為125.5。

同理若將float型資料0.5轉換為二進位制形式

0.5的二進位制形式為0.1,由於規定正數部分必須為1,將小數點右移1位,則為1.0*2^(-1),其階碼為-1+127=126,表示為01111110,而尾數1.0去掉整數部分為0,補齊0到23位00000000000000000000000,則其二進位制表示形式為

0 01111110 00000000000000000000000

由上分析可知float型資料最大表示範圍為1.11111111111111111111111*2^127=3.4*10^38

對於double型資料情況類似,只不過其階碼為11位,偏置量為1023,尾數為52位。

/*測試浮點型資料在記憶體中存放方式  2011.10.2*/ 

#include using namespace std;

int main(int argc, char *argv)

輸出結果為:

-5在上面已經知道float型125.5在記憶體中存放方式為:

00000000   低位址

01000010   高位址

因此對於p和p+1指向的單元,其中儲存的二進位制數表示的十進位制整數為0;

而對於p+2指向的單元,由於為char型指標,為帶符號的資料型別,因此11111011,符號位為1,則為負數,由於在記憶體中二進位制是以補碼儲存的,所以其真值為-5.

對於p+3指向的單元,01000010,為正數,則其大小為66。上面程式輸出結果驗證了其正確性。

浮點型在計算機內的儲存方式

步驟1 整數轉二進位制 不停 2的做法,將每個餘數依次相加 步驟2 小數轉二進位制 不同 2 1 計0,1 計1,用 x 1 繼續往後做 2操作 步驟3 整數部分和小數部分二進位制粘合起來,注意小數點不要去除 步驟5 將2進製變成1.x 2 n 次方的形式,整數 小數一共24位,小數點不計位數,對應...

整型與浮點型資料在計算機記憶體中的儲存

1 型別的歸類 整型家族 char unsigned char signed char 對於char來說,標準裡並不預設其為有符號還是無符號的,這個結果取決於編譯器 short signed short int unsigned short int int signed int unsigned i...

計算機內部數字的儲存 擴充套件

在對精度要求很高的系統中,或要對小數的運算結果進行比較時,需要特別謹慎 js中的小數運算是精確的嗎?不一定js中的整數運算是精確的嗎?不一定js中表示的整數是連續的嗎?不是,當 js 的數字很大的時候,不再連續 js中表示的最大數字是多少?最大連續整數 從1開始數到這個數字一直都是連續的,並且到下乙...