日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【转】计算机中浮点数的表示

發布時間:2025/3/18 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【转】计算机中浮点数的表示 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

【轉】計算機中浮點數的表示

來自:http://www.cnblogs.com/dolphin0520/archive/2011/10/02/2198280.html

  

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【這里是錯誤的,應為10000001,10000010是按課本上移碼規則算的,但實際中并不用移碼,而是用移碼-1,即2的移碼為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。上面程序輸出結果驗證了其正確性。

posted on 2018-07-17 19:32 時空觀察者9號 閱讀(...) 評論(...) 編輯 收藏

總結

以上是生活随笔為你收集整理的【转】计算机中浮点数的表示的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 欧美日本高清 | 亚洲国产片 | 午夜美女视频 | 伊人称影院 | 日本一区二区三区视频在线 | 国产强被迫伦姧在线观看无码 | 女生高潮视频在线观看 | 国产一级一片免费播放放a 丁香六月色 | 日韩精品欧美精品 | av在线地址 | 国产又黄又猛又粗 | 五月婷综合 | 丝袜脚交免费网站xx | 日本五十路在线 | 91麻豆精品国产午夜天堂 | 免费的一级黄色片 | 伊人影院综合在线 | 嫩草视频在线观看视频 | 久久人精品| 在线中文字幕观看 | 800av凹凸| 男女无遮挡xx00动态图120秒 | 操她视频网站 | 国产无码日韩精品 | 91免费影片 | 国产网站在线免费观看 | 亚洲精品无码不卡在线播he | 91色噜噜| 国产精品一区二区三区免费在线观看 | 国产嘿咻视频 | 99热久 | av成人在线免费观看 | 天使色吧 | 性欧美www| 黑森林av导航 | 国产美女无遮挡网站 | 成人免费黄色网址 | 一级黄色大片在线观看 | 欧美精品第1页 | 噼里啪啦国语电影 | 午夜在线观看视频网站 | 99av国产精品欲麻豆 | 日韩性网站 | 日本天堂网在线观看 | 日韩成人不卡 | а√天堂资源在线 | 美美女高清毛片视频免费观看 | 欧美一区视频在线 | 日本bdsm视频 | 欧产日产国产精品 | 天天干狠狠插 | 蜜臀视频在线观看 | 日日日日干 | 一区二区日韩av | 日韩123 | 中文字幕偷拍 | 99久久久无码国产精品衣服 | 国产h自拍 | 中国性xxx| 免费吸乳羞羞网站视频 | 日韩欧美一区二区一幕 | 丁香六月天婷婷 | 麻豆tube| 国产麻豆乱码精品一区二区三区 | 91精品久久久久久综合五月天 | 天天摸日日 | 国产一区视频在线播放 | 欧美激情综合色综合啪啪五月 | 日韩在线播放视频 | 久久av色| 熟妇人妻中文av无码 | 谁有免费的黄色网址 | 岛国av在线免费 | 国产精品天天狠天天看 | 久久久久无码国产精品不卡 | 国产免费一区二区三区网站免费 | www.色中色| 国产亚洲性欧美日韩在线观看软件 | 亚洲av日韩av在线观看 | 欧美一区二区三区婷婷 | 天天干夜夜嗨 | 波多野结衣一区二区 | 欧美日韩国产精品一区二区三区 | 一本到免费视频 | 韩国三级做爰视频 | 免费在线观看污网站 | 懂色av一区二区三区四区 | 污污动态图| 精品欧美乱码久久久久久 | 成人精品网| 国产成人精品无码免费看夜聊软件 | 欧美性激情 | 91在线视频在线观看 | 天天操天天爱天天干 | 日本福利网站 | 亚洲男人的天堂网 | 另类国产 | 波多野结衣在线观看一区二区三区 | 91黑丝在线观看 |