日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > > C語言與CPP編程
[導(dǎo)讀]我們在學(xué)習(xí)C語言時,通常認(rèn)為浮點數(shù)和小數(shù)是等價的,并沒有嚴(yán)格區(qū)分它們的概念,這也并沒有影響到我們的學(xué)習(xí),原因就是浮點數(shù)和小數(shù)是綁定在一起的,只有小數(shù)才使用浮點格式來存儲。其實,整數(shù)和小數(shù)可以都使用定點格式來存儲,也可以都使用浮點格式來存儲,但實際情況卻是,C語言使用定點格式存儲整數(shù),使用浮點格式存儲小數(shù),這是在 “數(shù)值范圍” 和 “數(shù)值精度” 兩項重要指標(biāo)之間追求平衡的結(jié)果。



1 前言

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

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

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

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

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

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

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

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

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

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

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

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

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

4 實例

浮點數(shù)19.625用float是如何存儲的:

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

5 float與double范圍和精度

范圍

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

  • float:

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

  • double:

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

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

其中負(fù)指數(shù)決定了浮點數(shù)所能表達(dá)的絕對值最小的非零數(shù);而正指數(shù)決定了浮點數(shù)所能表達(dá)的絕對值最大的數(shù),也即決定了浮點數(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ù)點后面有效數(shù)字就越多,因此精度就越高。浮點數(shù)在內(nèi)存中是按科學(xué)計數(shù)法來存儲的,其整數(shù)部分始終是一個隱含著的“1”,由于它是不變的,故不能對精度造成影響。

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

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

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

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

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

大家看到這里的問題了吧,有兩個 0 ,一個正 0 和一個負(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ī)律,采用移位存儲技術(shù),我們可以使用 8 位二進(jìn)制來表示從-127~+128共計 127 個負(fù)數(shù)+零(0)+ 128 個正數(shù)總共 256 個數(shù),看來使用移位存儲既沒有 +0 和 -0 的問題,又能充分使用新生成的8位二進(jìn)制數(shù)最大限度的表示單精度浮點數(shù)的冪指數(shù),是非常合理的。

歡迎小伙伴們四連走起:點贊、在看、留言、分享。你的四連是我更文的動力。

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護(hù)是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機(jī)驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機(jī)驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉