在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
电子发烧友
开通电子发烧友VIP会员 尊享10大特权
海量资料免费下载
精品直播免费看
优质内容免费畅学
课程9折专享价
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

浮點數在內存中的存儲

Q4MP_gh_c472c21 ? 來源:C語言與CPP編程 ? 2020-09-20 10:52 ? 次閱讀

1 前言

我們在學習 C語言時,通常認為浮點數和小數是等價的,并沒有嚴格區分它們的概念,這也并沒有影響到我們的學習,原因就是浮點數和小數是綁定在一起的,只有小數才使用浮點格式來存儲。

其實,整數和小數可以都使用定點格式來存儲,也可以都使用浮點格式來存儲,但實際情況卻是,C 語言使用定點格式存儲整數,使用浮點格式存儲小數,這是在 “數值范圍” 和 “數值精度” 兩項重要指標之間追求平衡的結果。

2 什么是浮點數?

浮點型簡單講就是實數的意思。浮點數在計算機中用以近似表示任意某個實數。具體的說,這個實數由一個整數或定點數(即尾數)乘以某個基數(計算機中通常是 2)的整數次冪得到,這種表示方法類似于基數為 10 的科學記數法。

3 浮點數在內存中的存儲

首先明確一點,無論是整型、浮點型還是字符等等數據類型在計算機底層都是以二進制的方式存儲的。

浮點數在內存中的存儲和整數不同,因為整數都可以轉換為一一對應的二進制數據。而浮點數的存儲是由符號位 (sign) + 指數位 (exponent) + 小數位 (fraction) 組成。

類型符號位指數尾數

int 和 float 同樣占據四個字節的內存,但是 float 所能表示的最大值比 int 大得多,其根本原因是浮點數在內存中是以指數的方式存儲。

浮點數轉換到內存中存儲的步驟分為如下三步:

將浮點數轉換成二進制

用科學計數法表示二進制浮點數

計算指數偏移后的值

對于第3點:計算指數時需要加上偏移量(后面有介紹為什么使用偏移量),而偏移量的值與浮點數的類型有關( float 偏移量值為 127 ,double 偏移量值為 1023)。比方對于指數 6,float 與 double 類型偏移后的值分別為:

float : 127 + 6 = 133

double:1023 + 6 = 1029

4 實例

浮點數19.625用float是如何存儲的:

將浮點數轉換成二進制:10011.101(將 19.625 整數部分采用除 2 取余,小數部分采用乘 2 取整法);

用科學計數法表示二進制浮點數:1.0011101*2^4;

計算指數偏移后的值:127 + 4 = 131 (10000011);

拼接綜上所述,float 類型的 19.625 在內存中的值為:0 - 10000011 - 001 1101 0000 0000 0000 0000。

5 float與double范圍和精度

范圍

float和double的范圍是由指數的位數來決定的。(因為表示的時候都是1.x * 2^Y的形式,所以忽略了1.x的效果,直接取指數表示浮點數的范圍)

float:

1bit(符號位) 8bits(指數位) 23bits(尾數位)

double:

1bit(符號位) 11bits(指數位) 52bits(尾數位)

于是,float的指數范圍為-127~+128,而double的指數范圍為-1023~+1024,并且指數位是按補碼的形式來劃分的。

其中負指數決定了浮點數所能表達的絕對值最小的非零數;而正指數決定了浮點數所能表達的絕對值最大的數,也即決定了浮點數的取值范圍。

float的范圍為-2^128 ~ +2^128,也即-3.40E+38 ~ +3.40E+38;

double的范圍為-2^1024 ~ +2^1024,也即-1.79E+308 ~ +1.79E+308。

精度

float和double的精度是由尾數的位數來決定的,尾數越多能表示的小數點后面有效數字就越多,因此精度就越高。浮點數在內存中是按科學計數法來存儲的,其整數部分始終是一個隱含著的“1”,由于它是不變的,故不能對精度造成影響。

float:2^23 = 8388608,一共七位,這意味著最多能有 7 位有效數字,但絕對能保證的為 6 位,也即float的精度為 6~7 位有效數字;

double:2^52 = 4503599627370496,一共 16 位,同理,double的精度為 15~16 位。

6 解剖:為什么要用偏移量的方式來計算指數?

如果不采用偏移量的方式:

8 位 2 進制數表示的有符號數范圍有兩個區間:0000 0000~0111 1111和1000 0000~1111 1111,分別為0~+127和-127~0。

大家看到這里的問題了吧,有兩個 0 ,一個正 0 和一個負 0。

如果采用偏移量的方式:

127 轉化為二進制是:0111 1111

那么

當我們要表示 -127,則有127-127即0111 1111 - 0111 1111 = 0000 0000

當我們要表示 -126,則有127-126即0111 1111 - 0111 1110 = 0000 0001

當我們要表示 -2,則有127-2即0111 1111 - 0000 0010 = 0111 1101

當我們要表示 -1,則有127-1即0111 1111 - 0000 0001 = 0111 1110

當我們要表示 0,則有0+127即0000 0000 + 0111 1111 = 0111 1111

當我們要表示 1,則有1+127即0000 0001 + 0111 1111 = 1000 0000

當我們要表示 2,則有1+127即0000 0010 + 0111 1111 = 1000 0001

當我們要表示128,則有128+127即1000 0000 + 0111 1111 = 1111 1111

由上面的例子,我們可以得出規律,采用移位存儲技術,我們可以使用 8 位二進制來表示從-127~+128共計 127 個負數+零(0)+ 128 個正數總共 256 個數,看來使用移位存儲既沒有 +0 和 -0 的問題,又能充分使用新生成的8位二進制數最大限度的表示單精度浮點數的冪指數,是非常合理的。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 二進制
    +關注

    關注

    2

    文章

    803

    瀏覽量

    42046
  • C語言
    +關注

    關注

    180

    文章

    7627

    瀏覽量

    139634
  • 浮點數
    +關注

    關注

    0

    文章

    61

    瀏覽量

    16040

原文標題:浮點數的秘密

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 0人收藏

    評論

    相關推薦

    PRINTF函數無法打印出浮點數內容是為什么?

    1、MCXN947低功耗adc,歷程中使用官方提供的PRINTF無法打印出浮點數內容。 2、同樣在mcuxpresso ide 也不可以打印浮點數,這是為什么呢? 3、使用的歷程是lpadc歷程。
    發表于 03-20 08:06

    labview寫入浮點數到匯川 PLC的數據轉換關鍵

    為32位無符號整型U32 2、將U32拆分為兩個U16,分高低位寫入PLC 3、在PLC,將低位寄存器設置為浮點數數據類型 4、結果:PLC中一直無法正確轉換。 原因及解決方法: 1、labview
    發表于 02-24 19:01

    西門子TIA Portal如何比較兩個浮點數相等

    概述: 由于浮點數的定義規則,導致浮點數不能通過二進制精確表示,所以在浮點數計算過程,會出現兩個值一樣的浮點數進行比較相等計算時結果并不相
    的頭像 發表于 01-06 10:07 ?522次閱讀
    西門子TIA Portal如何比較兩個<b class='flag-5'>浮點數</b>相等

    ADS1282采集到的數據傳到PC上應該怎么轉為浮點數

    我最近在用ADS1282,采集到的數據傳到PC上應該怎么轉為浮點數?比如說通過串口調試助手收到一個采樣點的數據為 FF FF 9D 17,它的真實浮點數是多少呢?我知道ADC是以補碼形式存的,是要將數據倒轉為17 9D FF FF,再與上0xFF,再float()嗎?還
    發表于 12-13 06:23

    TLV320AIC3106音頻芯片怎么發送、接收浮點數呢?

    TLV320AIC3106 音頻芯片怎么發送、接收浮點數呢?是把浮點數轉成整數嗎?如果是該怎么轉呢? 經AD采樣后得到的是整數,又該怎么轉換成原始的浮點數呢?
    發表于 11-05 07:13

    labview浮點數與十六進制字符串相互轉化

    與下位機數據交流及通訊時,經常有浮點數與十六進制字符串相互轉化的需求,經過兩天總結,找到了最簡潔的相互轉化的方法,萌新歡迎大佬指正,文件也附上。*附件:HEX字符串與浮點數轉換.rar
    發表于 10-21 19:51

    TMS320C6745浮點數字信號處理器技術簡介

    電子發燒友網站提供《TMS320C6745浮點數字信號處理器技術簡介.pdf》資料免費下載
    發表于 10-09 09:34 ?0次下載
    TMS320C6745<b class='flag-5'>浮點數</b>字信號處理器技術簡介

    分享在arduino 單片機浮點數轉換位數不夠,精度丟失的解決辦法

    arduino由于硬件限制,浮點數只有2位小數。但經過這個函數處理可以達到7位
    的頭像 發表于 08-27 14:34 ?1053次閱讀

    TMS320C6671定點和浮點數字信號處理器數據表

    電子發燒友網站提供《TMS320C6671定點和浮點數字信號處理器數據表.pdf》資料免費下載
    發表于 08-05 11:17 ?0次下載
    TMS320C6671定點和<b class='flag-5'>浮點數</b>字信號處理器數據表

    TMS320C6711D浮點數字信號處理器數據表

    電子發燒友網站提供《TMS320C6711D浮點數字信號處理器數據表.pdf》資料免費下載
    發表于 08-03 09:29 ?0次下載
    TMS320C6711D<b class='flag-5'>浮點數</b>字信號處理器數據表

    官方例程modbus slave rtu,浮點數精度不對是怎么回事?

    官方例程 modbus slave rtu, 浮點數精度不對,對保持寄存器設置一個浮點數,讀取到的浮點數結果精度只能到小數點后兩位,根本無法使用,用的是idf 5.1.2版本,開發環境是vscode。
    發表于 07-19 08:10

    請問如何打印浮點數或雙精度變量?

    如何打印浮點數或雙精度變量?
    發表于 07-12 08:24

    ESP8266_RTOS_SDK如何打印浮點數

    不適用于浮點數; 我的假設是編譯器沒有啟用浮點? 如果是這種情況,我不確定要啟用什么標志? 編譯器版本: xtensa-lx106-elf-gcc --版本
    發表于 07-09 06:56

    如何關閉ESP32-S3的FPU浮點數計算單元?

    如何關閉ESP32-S3的FPU浮點數計算單元。如題,之前的項目在esp32s2 上面運行良好,但是移植到esp32s3上后由于fpu造成浮點數計算無法在中斷中使用,并且也不能跨cpu去使用,對固件性能和穩定性造成了很大的影響
    發表于 06-27 07:32

    STM32CubeIDE printf浮點數浮點數丟失數值的原因?

    1、芯片:STM32F103C8T62、環境:STM32CubeIDE3、問題:printf浮點數浮點數數值丟失如 float A=25.6666;float B=24.7777;實際打印
    發表于 06-03 07:07

    電子發燒友

    中國電子工程師最喜歡的網站

    • 2931785位工程師會員交流學習
    • 獲取您個性化的科技前沿技術信息
    • 參加活動獲取豐厚的禮品
    主站蜘蛛池模板: 美女骚网站 | 天天射天天爽 | a网在线 | 羞羞漫画喷水漫画yy漫画 | 亚洲最新| 日本大片成人免费播放 | 日韩a级毛片免费观看 | 国产一级做a爰片久久毛片 国产一级做a爰片久久毛片男 | 99视频精品全国免费 | 三级视频网站在线观看播放 | 日本免费在线视频 | 日日骑夜夜操 | 免费一级特黄特色大片在线观看看 | 男人j进入女人j在线视频 | 一级毛片一级毛片一级毛片aa | 国产成年女一区二区三区 | 国产激情三级 | 亚洲免费网站在线观看 | 9984四虎永久免费网站 | 亚洲黄色第一页 | 激情五月视频 | 亚洲成a人一区二区三区 | 亲女乱h文小兰第一次 | 天天综合天天综合 | 欧美久久综合 | 国产精品美女www爽爽爽视频 | 欧美一级片观看 | 色视频日本 | 天堂资源最新版在线官网 | 99视频全部免费 | 在线精品国产成人综合第一页 | 一级录像| 亚洲欧美视频 | 国产特级毛片aaaaaa毛片 | 久久天天躁狠狠躁夜夜爽蜜月 | 成年网站在线播放 | 欧美日韩无 | 二级黄绝大片中国免费视频0 | 色多多免费观看在线 | 8050网午夜一级毛片免费不卡 | 一卡二卡≡卡四卡亚洲高清 |