欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入C/C++浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)方式詳解

 更新時(shí)間:2013年05月24日 18:12:09   作者:  
本篇文章是對(duì)C/C++浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)方式進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
任何數(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-0
float       符號(hào)位     階碼        尾數(shù)
                63        62-52       51-0
double    符號(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,其階碼表示形式為10000010
尾數(shù):有效數(shù)字位,即部分二進(jìn)制位(小數(shù)點(diǎn)后面的二進(jìn)制位),因?yàn)橐?guī)定M的整數(shù)部分恒為1,所以這個(gè)1就不進(jìn)行存儲(chǔ)了。
下面舉例說(shuō)明:
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   低地址
00000000
11111011
01000010   高地址
而反過(guò)來(lái)若要根據(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ù)情況類(lèi)似,只不過(guò)其階碼為11位,偏置量為1023,尾數(shù)為52位。

測(cè)試程序:
復(fù)制代碼 代碼如下:

/*測(cè)試浮點(diǎn)型數(shù)據(jù)在內(nèi)存中存放方式  2011.10.2*/
#include <iostream>
using namespace std;
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;
}

輸出結(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ù)類(lèi)型,因此11111011,符號(hào)位為1,則為負(fù)數(shù),由于在內(nèi)存中二進(jìn)制是以補(bǔ)碼存儲(chǔ)的,所以其真值為-5.
對(duì)于p+3指向的單元,01000010,為正數(shù),則其大小為66。上面程序輸出結(jié)果驗(yàn)證了其正確性。

相關(guān)文章

  • 深入理解c++常成員函數(shù)和常對(duì)象

    深入理解c++常成員函數(shù)和常對(duì)象

    下面小編就為大家?guī)?lái)一篇深入理解c++常成員函數(shù)和常對(duì)象。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧
    2016-05-05
  • VS2022中使用Copilot的圖文教程

    VS2022中使用Copilot的圖文教程

    大家都知道Copilot可以自動(dòng)幫助寫(xiě)代碼,那么這個(gè)工具是如果使用的呢?很多朋友不是很清楚,今天小編給大家分享一篇教程關(guān)于VS2022中使用Copilot的圖文教程,感興趣的朋友一起看看吧
    2022-04-04
  • C++示例講解string容器

    C++示例講解string容器

    c++相比c的一個(gè)好處就是實(shí)現(xiàn)了很多的容器和泛型算法,使得程序員的工作得到了很大的簡(jiǎn)化,本文重點(diǎn)給大家介紹C++string容器基本概念講解,需要的朋友參考下吧
    2022-07-07
  • c++ 巧開(kāi)平方的實(shí)現(xiàn)代碼

    c++ 巧開(kāi)平方的實(shí)現(xiàn)代碼

    如果沒(méi)有計(jì)算器,我們?nèi)绾吻?的平方根
    2013-05-05
  • C語(yǔ)言線(xiàn)性表之雙鏈表詳解

    C語(yǔ)言線(xiàn)性表之雙鏈表詳解

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言線(xiàn)性表之雙鏈表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02
  • Qt地圖自適應(yīng)拉伸的實(shí)現(xiàn)示例

    Qt地圖自適應(yīng)拉伸的實(shí)現(xiàn)示例

    最近需要寫(xiě)一個(gè)程序,要是讓qt到程序自適應(yīng),本文主要介紹了Qt地圖自適應(yīng)拉伸的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • C語(yǔ)言中的回調(diào)函數(shù)實(shí)例

    C語(yǔ)言中的回調(diào)函數(shù)實(shí)例

    如果函數(shù)A的指針作為函數(shù)B的參數(shù),在函數(shù)B中利用該指針調(diào)用函數(shù)A,則此時(shí)的A就是回調(diào)函數(shù)。
    2014-04-04
  • C++基于Boost.Asio實(shí)現(xiàn)端口映射器的過(guò)程詳解

    C++基于Boost.Asio實(shí)現(xiàn)端口映射器的過(guò)程詳解

    Boost.Asio 是一個(gè)功能強(qiáng)大的 C++ 庫(kù),用于異步編程和網(wǎng)絡(luò)編程,它提供了跨平臺(tái)的異步 I/O 操作,在這篇文章中,我們將深入分析一個(gè)使用 Boost.Asio 實(shí)現(xiàn)的簡(jiǎn)單端口映射服務(wù)器,文中有詳細(xì)的代碼講解,需要的朋友可以參考下
    2023-11-11
  • C語(yǔ)言實(shí)現(xiàn)數(shù)組移位、前移、后移與整體移動(dòng)實(shí)例代碼

    C語(yǔ)言實(shí)現(xiàn)數(shù)組移位、前移、后移與整體移動(dòng)實(shí)例代碼

    C語(yǔ)言中通??梢允褂醚h(huán)語(yǔ)句實(shí)現(xiàn)數(shù)組的移動(dòng),下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言實(shí)現(xiàn)數(shù)組移位、前移、后移與整體移動(dòng)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-03-03
  • c++下迭代器總結(jié)

    c++下迭代器總結(jié)

    大家好,本篇文章主要講的是c++下迭代器總結(jié),感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話(huà)記得收藏一下,方便下次瀏覽
    2021-12-12

最新評(píng)論