c/c++浮點(diǎn)數(shù)在內(nèi)存中存儲(chǔ)方式

任何數(shù)據(jù)在內(nèi)存中都是以二進(jìn)制的形式存儲(chǔ)的.

例如一個(gè)short型數(shù)據(jù)1156,其二進(jìn)制表示形式為00000100 10000100。則在Intel CPU架構(gòu)的系統(tǒng)中,存放方式為 10000100(低地址單元) 00000100(高地址單元),因?yàn)镮ntel CPU的架構(gòu)是小端模式腕铸。但是對(duì)于浮點(diǎn)數(shù)在內(nèi)存是如何存儲(chǔ)的?目前所有的C/C++編譯器都是采用IEEE所制定的標(biāo)準(zhǔn)浮點(diǎn)格式,即二進(jìn)制科學(xué)表示法铛碑。?

?在二進(jìn)制科學(xué)表示法中狠裹,S=M*2^N 主要由三部分構(gòu)成:符號(hào)位+階碼(N)+尾數(shù)(M)。對(duì)于float型數(shù)據(jù)汽烦,其二進(jìn)制有32位涛菠,其中符號(hào)位1位,階碼8位撇吞,尾數(shù)23位俗冻;對(duì)于double型數(shù)據(jù),其二進(jìn)制為64位牍颈,符號(hào)位1位迄薄,階碼11位,尾數(shù)52位煮岁。 31 30-23 22-0float 符號(hào)位 階碼 尾數(shù) 63 62-52 51-0double 符號(hào)位 階碼 尾數(shù)符號(hào)位:0表示正讥蔽,1表示負(fù)階碼:

這里階碼采用移碼表示涣易,對(duì)于float型數(shù)據(jù)其規(guī)定偏置量為127,階碼有正有負(fù),對(duì)于8位二進(jìn)制冶伞,則其表示范圍為-128-127新症,double型規(guī)定為1023,其表示范圍為-1024-1023响禽。比如對(duì)于float型數(shù)據(jù)徒爹,若階碼的真實(shí)值為2,則加上127后為129芋类,其階碼表示形式為10000001尾數(shù):有效數(shù)字位瀑焦,即部分二進(jìn)制位(小數(shù)點(diǎn)后面的二進(jìn)制位),因?yàn)橐?guī)定M的整數(shù)部分恒為1梗肝,所以這個(gè)1就不進(jìn)行存儲(chǔ)了。

下面舉例說明:float型數(shù)據(jù)125.5轉(zhuǎn)換為標(biāo)準(zhǔn)浮點(diǎn)格式125二進(jìn)制表示形式為1111101铺董,小數(shù)部分表示為二進(jìn)制為 1巫击,則125.5二進(jìn)制表示為1111101.1,由于規(guī)定尾數(shù)的整數(shù)部分恒為1精续,則表示為1.1111011*2^6坝锰,階碼為6,加上127為133重付,則表示為10000101顷级,而對(duì)于尾數(shù)將整數(shù)部分1去掉,為1111011确垫,在其后面補(bǔ)0使其位數(shù)達(dá)到23位弓颈,則為11110110000000000000000則其二進(jìn)制表示形式為0 10000101 11110110000000000000000,則在內(nèi)存中存放方式為:00000000 低地址000000001111101101000010 高地址而反過來若要根據(jù)二進(jìn)制形式求算浮點(diǎn)數(shù)如0 10000101 11110110000000000000000由于符號(hào)為為0删掀,則為正數(shù)翔冀。階碼為133-127=6,尾數(shù)為11110110000000000000000披泪,則其真實(shí)尾數(shù)為1.1111011纤子。

所以其大小為1.1111011*2^6,將小數(shù)點(diǎn)右移6位款票,得到1111101.1控硼,而1111101的十進(jìn)制為125,0.1的十進(jìn)制為1*2^(-1)=0.5艾少,所以其大小為125.5卡乾。同理若將float型數(shù)據(jù)0.5轉(zhuǎn)換為二進(jìn)制形式0.5的二進(jìn)制形式為0.1,由于規(guī)定正數(shù)部分必須為1姆钉,將小數(shù)點(diǎn)右移1位说订,則為1.0*2^(-1)抄瓦,其階碼為-1+127=126,表示為01111110陶冷,而尾數(shù)1.0去掉整數(shù)部分為0钙姊,補(bǔ)齊0到23位00000000000000000000000,則其二進(jìn)制表示形式為0 01111110 00000000000000000000000由

上分析可知float型數(shù)據(jù)最大表示范圍為1.11111111111111111111111*2^127=3.4*10^38對(duì)于double型數(shù)據(jù)情況類似埂伦,只不過其階碼為11位煞额,偏置量為1023,尾數(shù)為52位沾谜。測(cè)試程序:復(fù)制代碼/*測(cè)試浮點(diǎn)型數(shù)據(jù)在內(nèi)存中存放方式 2011.10.2*/ #includeusing namespace std;xian.想要學(xué)習(xí)的伙伴可以加一下群710520381.備注:久伴膊毁。歡迎大家進(jìn)群學(xué)習(xí)。

int main(int argc, char *argv[])

{

? ? float a=125.5;

? ? char *p=(char *)&a;

? ? printf("%d\n",*p);

? ? printf("%d\n",*(p+1));

? ? printf("%d\n",*(p+2));

? ? printf("%d\n",*(p+3));

? ? return 0;

}

復(fù)制代碼

輸出結(jié)果為:

0

0

-5

66

在上面已經(jīng)知道float型125.5在內(nèi)存中存放方式為:

00000000? 低地址

00000000

11111011

01000010? 高地址

因此對(duì)于p和p+1指向的單元基跑,其中存儲(chǔ)的二進(jìn)制數(shù)表示的十進(jìn)制整數(shù)為0婚温;

而對(duì)于p+2指向的單元,由于為char型指針媳否,為帶符號(hào)的數(shù)據(jù)類型栅螟,因此11111011,符號(hào)位為1篱竭,則為負(fù)數(shù)力图,由于在內(nèi)存中二進(jìn)制是以補(bǔ)碼存儲(chǔ)的,所以其真值為-5.

對(duì)于p+3指向的單元掺逼,01000010吃媒,為正數(shù),則其大小為66吕喘。上面程序輸出結(jié)果驗(yàn)證了其正確性赘那。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市氯质,隨后出現(xiàn)的幾起案子漓概,更是在濱河造成了極大的恐慌,老刑警劉巖病梢,帶你破解...
    沈念sama閱讀 211,376評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件胃珍,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡蜓陌,警方通過查閱死者的電腦和手機(jī)觅彰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來钮热,“玉大人填抬,你說我怎么就攤上這事∷砥冢” “怎么了飒责?”我有些...
    開封第一講書人閱讀 156,966評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵赘娄,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我宏蛉,道長(zhǎng)遣臼,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,432評(píng)論 1 283
  • 正文 為了忘掉前任拾并,我火速辦了婚禮揍堰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘嗅义。我一直安慰自己屏歹,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,519評(píng)論 6 385
  • 文/花漫 我一把揭開白布之碗。 她就那樣靜靜地躺著蝙眶,像睡著了一般。 火紅的嫁衣襯著肌膚如雪褪那。 梳的紋絲不亂的頭發(fā)上械馆,一...
    開封第一講書人閱讀 49,792評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音武通,去河邊找鬼。 笑死珊搀,一個(gè)胖子當(dāng)著我的面吹牛冶忱,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播境析,決...
    沈念sama閱讀 38,933評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼囚枪,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了劳淆?” 一聲冷哼從身側(cè)響起链沼,我...
    開封第一講書人閱讀 37,701評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎沛鸵,沒想到半個(gè)月后括勺,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,143評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡曲掰,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,488評(píng)論 2 327
  • 正文 我和宋清朗相戀三年疾捍,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片栏妖。...
    茶點(diǎn)故事閱讀 38,626評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡乱豆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出吊趾,到底是詐尸還是另有隱情宛裕,我是刑警寧澤瑟啃,帶...
    沈念sama閱讀 34,292評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站揩尸,受9級(jí)特大地震影響蛹屿,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜疲酌,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,896評(píng)論 3 313
  • 文/蒙蒙 一蜡峰、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧朗恳,春花似錦湿颅、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至怀浆,卻和暖如春谊囚,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背执赡。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來泰國(guó)打工镰踏, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人沙合。 一個(gè)月前我還...
    沈念sama閱讀 46,324評(píng)論 2 360
  • 正文 我出身青樓奠伪,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親首懈。 傳聞我的和親對(duì)象是個(gè)殘疾皇子绊率,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,494評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容