一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - 深入C/C++浮點數在內存中的存儲方式詳解

深入C/C++浮點數在內存中的存儲方式詳解

2020-12-07 11:49C++教程網 C/C++

本篇文章是對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   低地址
00000000
11111011
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 <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;
}


輸出結果為:
0
0
-5
66

在上面已經知道float型125.5在內存中存放方式為:
00000000   低地址
00000000
11111011
01000010   高地址
因此對于p和p+1指向的單元,其中存儲的二進制數表示的十進制整數為0;
而對于p+2指向的單元,由于為char型指針,為帶符號的數據類型,因此11111011,符號位為1,則為負數,由于在內存中二進制是以補碼存儲的,所以其真值為-5.
對于p+3指向的單元,01000010,為正數,則其大小為66。上面程序輸出結果驗證了其正確性。

延伸 · 閱讀

精彩推薦
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
主站蜘蛛池模板: 国产欧美日韩图片一区二区 | 国产91精品久久久久久久 | 青青青青青国产费线在线观看 | 午夜香蕉成视频人网站高清版 | 亚洲精品一线二线三线 | 国产精品伊人 | bbc japanese黑人强行 | 72张让男人一看就硬的图片 | 欧美猛男同志同性video | 欧美日韩久久中文字幕 | 欧美黑人换爱交换乱理伦片 | 天天综合色天天综合 | 日本粉色视频 | 阿 好深 快点 老师受不了 | 99色在线播放 | 亚洲精品第三页 | 日本小网站| 国产成人免费在线观看 | 污黄在线观看 | 青青青手机在线视频 | 成人福利在线 | 日本亚洲免费 | 欧美精品一区二区三区免费播放 | 好爽好舒服视频 | 亚洲人成网站在线观看播放青青 | 欧美性xxxxx 欧美性bbbbbxxxxxddd | 白丝打脚枪| 特黄特色大片免费视频播放 | 国产久热香蕉在线观看 | 国产愉拍| 爱爱一级视频 | 草逼视频网站 | 国产精品免费精品自在线观看 | 亚洲天堂2015| 办公室出轨秘书高h | 亚洲 日韩 自拍 视频一区 | 暖暖暖免费观看在线观看 | 国色天香视频完整版 | 欧美精品一区二区在线观看 | 亚洲成人第一 | 成年女人毛片免费观看中文w |