成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

浮點數的秘密

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

 [[342164]]

1 前言

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

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

2 什么是浮點數?

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

3 浮點數在內存中的存儲

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

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

  1. 類型  符號位 指數  尾數 
  2. Float   1位(第31位)    8位(第23~30位) 23位(第0~22位) 
  3. Double  1位(第63位)    11位(第52~62位)    52位(第0~51位) 

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位二進制數最大限度的表示單精度浮點數的冪指數,是非常合理的。

本文轉載自微信公眾號「C語言與CPP編程」,可以通過以下二維碼關注。轉載本文請聯系C語言與CPP編程公眾號。

 

責任編輯:武曉燕 來源: C語言與CPP編程
相關推薦

2023-07-05 08:00:58

Redis數據庫

2017-10-16 10:42:27

前端JavaScript浮點數

2018-08-24 10:16:23

內存浮點數存儲

2011-05-25 14:10:38

浮點數

2015-12-02 10:21:34

JavaScript浮點數精度調整

2020-10-12 06:38:08

存儲定點數

2024-05-31 08:38:35

Python浮點數屬性

2010-07-22 17:39:44

2010-01-15 15:21:35

C++

2021-10-19 14:04:28

C++類型數字

2009-05-19 10:10:01

Oracle時間加減時間操作

2021-11-15 09:32:06

浮點面試Java

2022-06-15 15:44:21

無損數據壓縮鴻蒙

2025-04-01 07:50:00

Dinero.js前端開發

2024-07-11 15:50:36

2024-08-23 08:43:08

2025-03-03 04:20:00

2023-11-08 13:32:00

JavaScript浮點數計算

2025-01-17 09:20:00

2025-03-14 10:34:22

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 中文字幕久久精品 | 亚洲高清视频一区二区 | 日韩综合网 | 国产97视频在线观看 | 亚洲精品视频一区二区三区 | 国产精品自产拍在线观看蜜 | 操操操操操 | 欧美精品福利视频 | 日韩免费在线视频 | www.久久久久久久久久久久 | 狠狠干网站 | 久久精品欧美一区二区三区麻豆 | 色吧久久 | 欧美成人免费在线 | 91在线影院 | 成人动漫视频网站 | 亚洲午夜精品一区二区三区 | 国产精品一区二区视频 | 欧美久久久久久 | 亚洲精品在线观看网站 | a网站在线观看 | 国产黄色在线观看 | 亚洲人成一区二区三区性色 | 亚洲九色 | 日韩在线一区二区三区 | 亚洲成年在线 | 午夜精品久久久久久久久久久久久 | 一区二区不卡视频 | 中文字幕视频在线看 | 欧美日韩精品在线免费观看 | 久久国产精品一区二区三区 | 亚洲香蕉在线视频 | 国产乱码久久久久久 | 久久成人一区 | 在线视频一区二区三区 | 黄色国产 | 秋霞影院一区二区 | 久久久久久色 | 精品国产一区二区三区久久久蜜月 | 国产小视频在线观看 | 日本精品一区二区三区在线观看视频 |