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

C/C++的浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)方式分析及實(shí)例

 更新時(shí)間:2016年11月27日 16:55:41   作者:海 子  
這篇文章主要介紹了C/C++的浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)方式分析及實(shí)例的相關(guān)資料,需要的朋友可以參考下

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-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ǔ)了。

下面舉例說明:

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   高地址

而反過來若要根據(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è)試程序:


/*測(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ù)類型,因此11111011,符號(hào)位為1,則為負(fù)數(shù),由于在內(nèi)存中二進(jìn)制是以補(bǔ)碼存儲(chǔ)的,所以其真值為-5.

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

感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

  • c++??復(fù)制消除問題解決示例詳析

    c++??復(fù)制消除問題解決示例詳析

    這篇文章主要為大家介紹了c++??復(fù)制消除問題解決示例詳析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • C++關(guān)鍵字thread_local學(xué)習(xí)筆記

    C++關(guān)鍵字thread_local學(xué)習(xí)筆記

    這篇文章主要為大家介紹了C++關(guān)鍵字thread_local學(xué)習(xí)筆記,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • 一張圖總結(jié)C++中關(guān)于指針的那些事

    一張圖總結(jié)C++中關(guān)于指針的那些事

    今天小編就為大家分享一篇關(guān)于一圖總結(jié)C++中關(guān)于指針的那些事,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • 實(shí)現(xiàn)C語言常用字符串庫函數(shù)

    實(shí)現(xiàn)C語言常用字符串庫函數(shù)

    這篇文章主要為大家介紹了如何實(shí)現(xiàn)C語言常用字符串庫函數(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • 詳解C語言內(nèi)核中的鏈表與結(jié)構(gòu)體

    詳解C語言內(nèi)核中的鏈表與結(jié)構(gòu)體

    Windows內(nèi)核中是無法使用vector容器等數(shù)據(jù)結(jié)構(gòu)的,當(dāng)我們需要保存一個(gè)結(jié)構(gòu)體數(shù)組時(shí),就需要使用內(nèi)核中提供的專用鏈表結(jié)構(gòu)。本文分享了幾個(gè)內(nèi)核中使用鏈表存儲(chǔ)多個(gè)結(jié)構(gòu)體的通用案例,希望對(duì)你有所幫助
    2022-09-09
  • C++ 動(dòng)態(tài)創(chuàng)建按鈕及 按鈕的消息響應(yīng)

    C++ 動(dòng)態(tài)創(chuàng)建按鈕及 按鈕的消息響應(yīng)

    這篇文章主要介紹了C++ 動(dòng)態(tài)創(chuàng)建按鈕及 按鈕的消息響應(yīng)的相關(guān)資料,需要的朋友可以參考下
    2015-06-06
  • C語言實(shí)現(xiàn)線性表的基本操作詳解

    C語言實(shí)現(xiàn)線性表的基本操作詳解

    線性表是最基本、最簡(jiǎn)單、也是最常用的一種數(shù)據(jù)結(jié)構(gòu)。一個(gè)線性表是n個(gè)具有相同特性的數(shù)據(jù)元素的有限序列,這篇文章帶你學(xué)習(xí)如何通過C語言實(shí)現(xiàn)線性表的順序存儲(chǔ)和鏈?zhǔn)酱鎯?chǔ)
    2021-11-11
  • C++ 隨機(jī)數(shù)與隨機(jī)種子數(shù)的實(shí)例

    C++ 隨機(jī)數(shù)與隨機(jī)種子數(shù)的實(shí)例

    這篇文章主要介紹了C++ 隨機(jī)數(shù)與隨機(jī)種子數(shù)的實(shí)例的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • C語言動(dòng)態(tài)內(nèi)存分配和內(nèi)存操作函數(shù)使用詳解

    C語言動(dòng)態(tài)內(nèi)存分配和內(nèi)存操作函數(shù)使用詳解

    但是在實(shí)際的編程中,往往會(huì)發(fā)生這種情況,即所需的內(nèi)存空間取決于實(shí)際輸入的數(shù)據(jù),而無法預(yù)先確定 。為了解決上述問題,C語言提供了一些內(nèi)存管理函數(shù),這些內(nèi)存管理函數(shù)可以按需要?jiǎng)討B(tài)的分配內(nèi)存空間,也可把不再使用的空間回收再次利用
    2022-12-12
  • 淺談C++11的std::mem_fn源碼解析

    淺談C++11的std::mem_fn源碼解析

    本文是基于gcc-4.9.0的源代碼進(jìn)行分析,std::mem_fn是C++11才加入標(biāo)準(zhǔn)的,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06

最新評(píng)論