色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

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

3天內不再提示

什么是浮點數?浮點數在內存中的存儲

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

1 前言

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

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

2 什么是浮點數?

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

3 浮點數在內存中的存儲

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

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

1.jpg

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范圍和精度

范圍

floatdouble的范圍是由指數的位數來決定的。(因為表示的時候都是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

精度

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

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

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

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

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

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

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

如果采用偏移量的方式:

127 轉化為二進制是:0111 1111

那么

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

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

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

審核編輯:劉清

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

    關注

    0

    文章

    60

    瀏覽量

    15868
收藏 人收藏

    評論

    相關推薦

    小數在內存是如何存儲的?為什么C語言中的浮點數不支持位移操作?

    小數在內存是如何存儲的?為什么C語言中的浮點數不支持位移操作?
    發表于 08-16 09:24 ?1048次閱讀
    小數<b class='flag-5'>在內存</b><b class='flag-5'>中</b>是如何<b class='flag-5'>存儲</b>的?為什么C語言中的<b class='flag-5'>浮點數</b>不支持位移操作?

    浮點數如何存儲

    浮點數如何存儲玩轉浮點數
    發表于 12-30 07:10

    浮點數的表示方法

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

    浮點數常用的編碼方法

    浮點數常用的編碼方法  前面已經說到,在計算機內,浮點數被表示為如下格式:    通常情況
    發表于 10-13 17:21 ?4483次閱讀
    <b class='flag-5'>浮點數</b>常用的編碼方法

    modbus 如何讀取浮點數

    本文為大家介紹modbus讀取浮點數的兩個程序設計。
    發表于 02-08 10:03 ?1.5w次閱讀

    單片機浮點數運算的源碼設計

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

    Xilinx怎么定點數浮點數

    轉化為的浮點數可以是單精度也可以是雙精度。
    發表于 07-05 08:09 ?3876次閱讀
    Xilinx怎么定<b class='flag-5'>點數</b>轉<b class='flag-5'>浮點數</b>

    浮點數在內存存儲

    浮點數在內存存儲和整數不同,因為整數都可以轉換為一一對應的二進制數據。而浮點數存儲是由符號
    的頭像 發表于 09-20 10:52 ?4053次閱讀
    <b class='flag-5'>浮點數</b><b class='flag-5'>在內存</b><b class='flag-5'>中</b>的<b class='flag-5'>存儲</b>

    談一談浮點數的精度問題

    還是要從浮點數存儲和標識出發來處理該問題,既然浮點數天然就存在一定的誤差,而有時候計算又無法獲得唯一的數值,如下圖所示,浮點數計算出來的實軸上的值都會因為
    的頭像 發表于 08-11 14:28 ?4587次閱讀
    談一談<b class='flag-5'>浮點數</b>的精度問題

    什么是浮點數

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

    PLC浮點數的二進制表示

    我們日常使用的各類數據,都是以二進制的方式存儲的。以浮點數為例,在PLC其表示方式使用了IEEE 754標準。許多編程語言中浮點數的實現也遵循該標準。
    的頭像 發表于 03-23 13:50 ?5281次閱讀
    PLC<b class='flag-5'>中</b><b class='flag-5'>浮點數</b>的二進制表示

    西門子PLC浮點數程序案例分享

    64位浮點數保存于VB0開始的存儲,轉換得出的32位浮點數保存于VD100
    發表于 10-27 17:07 ?3284次閱讀
    西門子PLC<b class='flag-5'>浮點數</b>程序案例分享

    單精度和雙精度浮點數的區別

    在計算機科學和數值計算浮點數是一種用于表示實數的數據類型。浮點數有兩種精度級別:單精度和雙精度。這兩種精度級別在表示范圍、精度和存儲空間等方面都有所不同。本文將詳細介紹單精度和雙精
    的頭像 發表于 12-13 10:55 ?1.1w次閱讀

    單精度和雙精度浮點數的區別

    單精度和雙精度是計算機中表示浮點數的兩種不同的精度。在計算機浮點數用來表示帶有小數部分的實數,而單精度和雙精度用來表示浮點數的精確程度不同。在以下文章
    的頭像 發表于 12-15 10:25 ?5429次閱讀

    modbus浮點數怎么讀取

    Modbus是一種通信協議,常用于工業自動化系統的設備之間的通信。它支持多種數據類型,包括整數、浮點數、字符串等。浮點數在工業領域中廣泛應用,因此了解如何讀取和處理Modbus浮點數
    的頭像 發表于 12-28 14:38 ?6208次閱讀
    主站蜘蛛池模板: 帅哥男男GV在线1080P| 99国产精品人妻无码免费| 国产精品久久人妻无码蜜 | 中文字幕精品视频在线| 国产午夜精品一区理论片飘花| 日日碰狠狠躁久久躁77777| 99久久免费国产精品特黄| 久久这里只有精品视频e| 亚洲欧美一区二区三区四区| 国产精品久久久亚洲偷窥女厕| 千禧金瓶梅快播| a视频免费在线| 免费一级特黄欧美大片久久网| 在线欧美 精品 第1页| 久久黄色免费| 伊人久久青草| 久久精品视在线观看85| 亚洲中文在线精品国产| 狠狠啪在线香蕉| 亚洲人成77777| 饥渴的护士自慰被发现| 亚洲色tu| 久久99精品视频| 一个人免费视频在线观看| 久久999视频| 一扒二脱三插片在线观看| 国模沟沟一区二区三区| 亚洲国产精品无码AV久久久| 国产小视频国产精品| 亚洲精品午夜VA久久成人| 狠日狠干日曰射| 一个人HD高清在线观看免费视频| 九色PORNY蝌蚪视频首页| 在线播放日韩欧美亚洲日本| 久久综合色视频| 91福利在线观看| 漂亮的保姆3中文版完整版| 成年视频xxxxxx在线| 天美麻豆成人AV精品| 国产精品人妻午夜福利| 亚洲精品视频观看|