0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

什么是浮點(diǎn)數(shù)?浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)

冬至子 ? 來源:C語言與CPP編程 ? 作者:LeeWay ? 2022-11-09 11:07 ? 次閱讀

1 前言

我們?cè)趯W(xué)習(xí) C 語言時(shí),通常認(rèn)為浮點(diǎn)數(shù)和小數(shù)是等價(jià)的,并沒有嚴(yán)格區(qū)分它們的概念,這也并沒有影響到我們的學(xué)習(xí),原因就是浮點(diǎn)數(shù)和小數(shù)是綁定在一起的,只有小數(shù)才使用浮點(diǎn)格式來存儲(chǔ)。

其實(shí),整數(shù)和小數(shù)可以都使用定點(diǎn)格式來存儲(chǔ),也可以都使用浮點(diǎn)格式來存儲(chǔ),但實(shí)際情況卻是,C 語言使用定點(diǎn)格式存儲(chǔ)整數(shù),使用浮點(diǎn)格式存儲(chǔ)小數(shù),這是在 “數(shù)值范圍” 和 “數(shù)值精度” 兩項(xiàng)重要指標(biāo)之間追求平衡的結(jié)果。

2 什么是浮點(diǎn)數(shù)?

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

3 浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)

首先明確一點(diǎn),無論是整型、浮點(diǎn)型還是字符等等數(shù)據(jù)類型在計(jì)算機(jī)底層都是以二進(jìn)制的方式存儲(chǔ)的。

浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)和整數(shù)不同,因?yàn)檎麛?shù)都可以轉(zhuǎn)換為一一對(duì)應(yīng)的二進(jìn)制數(shù)據(jù)。而浮點(diǎn)數(shù)的存儲(chǔ)是由符號(hào)位 (sign) + 指數(shù)位 (exponent) + 小數(shù)位 (fraction) 組成。

1.jpg

int 和 float 同樣占據(jù)四個(gè)字節(jié)的內(nèi)存,但是 float 所能表示的最大值比 int 大得多,其根本原因是浮點(diǎn)數(shù)在內(nèi)存中是以指數(shù)的方式存儲(chǔ)。

浮點(diǎn)數(shù)轉(zhuǎn)換到內(nèi)存中存儲(chǔ)的步驟分為如下三步:

  • 將浮點(diǎn)數(shù)轉(zhuǎn)換成二進(jìn)制
  • 用科學(xué)計(jì)數(shù)法表示二進(jìn)制浮點(diǎn)數(shù)
  • 計(jì)算指數(shù)偏移后的值

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

  • float : 127 + 6 = 133
  • double:1023 + 6 = 1029

4 實(shí)例

浮點(diǎn)數(shù)19.625用float是如何存儲(chǔ)的:

  • 將浮點(diǎn)數(shù)轉(zhuǎn)換成二進(jìn)制:10011.101(將 19.625 整數(shù)部分采用除 2 取余,小數(shù)部分采用乘 2 取整法);
  • 用科學(xué)計(jì)數(shù)法表示二進(jìn)制浮點(diǎn)數(shù):1.0011101*2^4;
  • 計(jì)算指數(shù)偏移后的值:127 + 4 = 131 (10000011);
  • 拼接綜上所述,float 類型的 19.625 在內(nèi)存中的值為:0 - 10000011 - 001 1101 0000 0000 0000 0000。

5 float與double范圍和精度

范圍

floatdouble的范圍是由指數(shù)的位數(shù)來決定的。(因?yàn)楸硎镜臅r(shí)候都是1.x * 2^Y的形式,所以忽略了1.x的效果,直接取指數(shù)表示浮點(diǎn)數(shù)的范圍)

  • float:

1bit(符號(hào)位) 8bits(指數(shù)位) 23bits(尾數(shù)位)

  • double:

1bit(符號(hào)位) 11bits(指數(shù)位) 52bits(尾數(shù)位)

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

其中負(fù)指數(shù)決定了浮點(diǎn)數(shù)所能表達(dá)的絕對(duì)值最小的非零數(shù);而正指數(shù)決定了浮點(diǎn)數(shù)所能表達(dá)的絕對(duì)值最大的數(shù),也即決定了浮點(diǎn)數(shù)的取值范圍。

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

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

精度

floatdouble的精度是由尾數(shù)的位數(shù)來決定的,尾數(shù)越多能表示的小數(shù)點(diǎn)后面有效數(shù)字就越多,因此精度就越高。浮點(diǎn)數(shù)在內(nèi)存中是按科學(xué)計(jì)數(shù)法來存儲(chǔ)的,其整數(shù)部分始終是一個(gè)隱含著的“1”,由于它是不變的,故不能對(duì)精度造成影響。

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

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

6 解剖:為什么要用偏移量的方式來計(jì)算指數(shù)?

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

8 位 2 進(jìn)制數(shù)表示的有符號(hào)數(shù)范圍有兩個(gè)區(qū)間:0000 0000~0111 11111000 0000~1111 1111,分別為0~+127-127~0

大家看到這里的問題了吧,有兩個(gè) 0 ,一個(gè)正 0 和一個(gè)負(fù) 0。

如果采用偏移量的方式:

127 轉(zhuǎn)化為二進(jìn)制是:0111 1111

那么

  • 當(dāng)我們要表示 -127,則有127-1270111 1111 - 0111 1111 = 0000 0000
  • 當(dāng)我們要表示 -126,則有127-1260111 1111 - 0111 1110 = 0000 0001
  • 當(dāng)我們要表示 -2,則有127-20111 1111 - 0000 0010 = 0111 1101
  • 當(dāng)我們要表示 -1,則有127-10111 1111 - 0000 0001 = 0111 1110
  • 當(dāng)我們要表示 0,則有0+1270000 0000 + 0111 1111 = 0111 1111
  • 當(dāng)我們要表示 1,則有1+1270000 0001 + 0111 1111 = 1000 0000
  • 當(dāng)我們要表示 2,則有1+1270000 0010 + 0111 1111 = 1000 0001

當(dāng)我們要表示128,則有128+127即1000 0000 + 0111 1111 = 1111 1111

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

審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    小數(shù)在內(nèi)存是如何存儲(chǔ)的?為什么C語言中的浮點(diǎn)數(shù)不支持位移操作?

    小數(shù)在內(nèi)存是如何存儲(chǔ)的?為什么C語言中的浮點(diǎn)數(shù)不支持位移操作?
    發(fā)表于 08-16 09:24 ?1058次閱讀
    小數(shù)<b class='flag-5'>在內(nèi)存</b><b class='flag-5'>中</b>是如何<b class='flag-5'>存儲(chǔ)</b>的?為什么C語言中的<b class='flag-5'>浮點(diǎn)數(shù)</b>不支持位移操作?

    浮點(diǎn)數(shù)如何存儲(chǔ)

    浮點(diǎn)數(shù)如何存儲(chǔ)玩轉(zhuǎn)浮點(diǎn)數(shù)
    發(fā)表于 12-30 07:10

    浮點(diǎn)數(shù)的表示方法

    浮點(diǎn)數(shù)的表示方法  浮點(diǎn)數(shù),是指小數(shù)點(diǎn)在數(shù)據(jù)的位置可以左右移動(dòng)的數(shù)據(jù)。它通常被表示成:    N = M* RE  這里的M(Mantissa)被稱為浮點(diǎn)數(shù)
    發(fā)表于 10-13 17:13 ?1.6w次閱讀
    <b class='flag-5'>浮點(diǎn)數(shù)</b>的表示方法

    浮點(diǎn)數(shù)常用的編碼方法

    浮點(diǎn)數(shù)常用的編碼方法  前面已經(jīng)說到,在計(jì)算機(jī)內(nèi),浮點(diǎn)數(shù)被表示為如下格式:    通常情況
    發(fā)表于 10-13 17:21 ?4495次閱讀
    <b class='flag-5'>浮點(diǎn)數(shù)</b>常用的編碼方法

    modbus 如何讀取浮點(diǎn)數(shù)

    本文為大家介紹modbus讀取浮點(diǎn)數(shù)的兩個(gè)程序設(shè)計(jì)。
    發(fā)表于 02-08 10:03 ?1.5w次閱讀

    單片機(jī)浮點(diǎn)數(shù)運(yùn)算的源碼設(shè)計(jì)

    單片機(jī)執(zhí)行程序的過程,實(shí)際上就是執(zhí)行我們所編制程序的過程。即逐條指令的過程。本文詳細(xì)介紹了浮點(diǎn)數(shù)在單片機(jī)的表示方式和匯編子程序,浮點(diǎn)數(shù)比定點(diǎn)數(shù)加減法要困難,但是克服了定
    的頭像 發(fā)表于 03-07 15:19 ?1w次閱讀
    單片機(jī)<b class='flag-5'>浮點(diǎn)數(shù)</b>運(yùn)算的源碼設(shè)計(jì)

    Xilinx怎么定點(diǎn)數(shù)轉(zhuǎn)浮點(diǎn)數(shù)

    轉(zhuǎn)化為的浮點(diǎn)數(shù)可以是單精度也可以是雙精度。
    發(fā)表于 07-05 08:09 ?3877次閱讀
    Xilinx怎么定<b class='flag-5'>點(diǎn)數(shù)</b>轉(zhuǎn)<b class='flag-5'>浮點(diǎn)數(shù)</b>

    浮點(diǎn)數(shù)在內(nèi)存存儲(chǔ)

    浮點(diǎn)數(shù)在內(nèi)存存儲(chǔ)和整數(shù)不同,因?yàn)檎麛?shù)都可以轉(zhuǎn)換為一一對(duì)應(yīng)的二進(jìn)制數(shù)據(jù)。而浮點(diǎn)數(shù)存儲(chǔ)是由符號(hào)
    的頭像 發(fā)表于 09-20 10:52 ?4067次閱讀
    <b class='flag-5'>浮點(diǎn)數(shù)</b><b class='flag-5'>在內(nèi)存</b><b class='flag-5'>中</b>的<b class='flag-5'>存儲(chǔ)</b>

    談一談浮點(diǎn)數(shù)的精度問題

    還是要從浮點(diǎn)數(shù)存儲(chǔ)和標(biāo)識(shí)出發(fā)來處理該問題,既然浮點(diǎn)數(shù)天然就存在一定的誤差,而有時(shí)候計(jì)算又無法獲得唯一的數(shù)值,如下圖所示,浮點(diǎn)數(shù)計(jì)算出來的實(shí)軸上的值都會(huì)因?yàn)?/div>
    的頭像 發(fā)表于 08-11 14:28 ?4604次閱讀
    談一談<b class='flag-5'>浮點(diǎn)數(shù)</b>的精度問題

    什么是浮點(diǎn)數(shù)

    Python數(shù)據(jù)類型第一種:字符串(str)。 Python數(shù)據(jù)類型第二種:整數(shù)(int)。 Python數(shù)據(jù)類型第三種:浮點(diǎn)數(shù),浮點(diǎn)數(shù)的英文名是float,浮點(diǎn)數(shù)沒有簡(jiǎn)寫。
    的頭像 發(fā)表于 02-23 14:58 ?4630次閱讀

    PLC浮點(diǎn)數(shù)的二進(jìn)制表示

    我們?nèi)粘J褂玫母黝悢?shù)據(jù),都是以二進(jìn)制的方式存儲(chǔ)的。以浮點(diǎn)數(shù)為例,在PLC其表示方式使用了IEEE 754標(biāo)準(zhǔn)。許多編程語言中浮點(diǎn)數(shù)的實(shí)現(xiàn)也遵循該標(biāo)準(zhǔn)。
    的頭像 發(fā)表于 03-23 13:50 ?5340次閱讀
    PLC<b class='flag-5'>中</b><b class='flag-5'>浮點(diǎn)數(shù)</b>的二進(jìn)制表示

    西門子PLC浮點(diǎn)數(shù)程序案例分享

    64位浮點(diǎn)數(shù)保存于VB0開始的存儲(chǔ)區(qū),轉(zhuǎn)換得出的32位浮點(diǎn)數(shù)保存于VD100
    發(fā)表于 10-27 17:07 ?3326次閱讀
    西門子PLC<b class='flag-5'>浮點(diǎn)數(shù)</b>程序案例分享

    單精度和雙精度浮點(diǎn)數(shù)的區(qū)別

    在計(jì)算機(jī)科學(xué)和數(shù)值計(jì)算,浮點(diǎn)數(shù)是一種用于表示實(shí)數(shù)的數(shù)據(jù)類型。浮點(diǎn)數(shù)有兩種精度級(jí)別:?jiǎn)尉群碗p精度。這兩種精度級(jí)別在表示范圍、精度和存儲(chǔ)空間等方面都有所不同。本文將詳細(xì)介紹單精度和雙精
    的頭像 發(fā)表于 12-13 10:55 ?1.1w次閱讀

    單精度和雙精度浮點(diǎn)數(shù)的區(qū)別

    單精度和雙精度是計(jì)算機(jī)中表示浮點(diǎn)數(shù)的兩種不同的精度。在計(jì)算機(jī),浮點(diǎn)數(shù)用來表示帶有小數(shù)部分的實(shí)數(shù),而單精度和雙精度用來表示浮點(diǎn)數(shù)的精確程度不同。在以下文章
    的頭像 發(fā)表于 12-15 10:25 ?5456次閱讀

    modbus浮點(diǎn)數(shù)怎么讀取

    Modbus是一種通信協(xié)議,常用于工業(yè)自動(dòng)化系統(tǒng)的設(shè)備之間的通信。它支持多種數(shù)據(jù)類型,包括整數(shù)、浮點(diǎn)數(shù)、字符串等。浮點(diǎn)數(shù)在工業(yè)領(lǐng)域中廣泛應(yīng)用,因此了解如何讀取和處理Modbus浮點(diǎn)數(shù)
    的頭像 發(fā)表于 12-28 14:38 ?6355次閱讀