C語言中32位浮點數的格式

GNU C為例,它遵循 IEEE 754-2008標準中制定的浮點表示規范。在該規范中定義了 5種不同大小的基礎二進制浮點格式,包括:16位,32位,64位,128位,256位。其中,32位的格式被用作標準 C類型的 float64位的格式被用作標準 C類型的 double128位的格式被用作標準 C類型的 long double

每種浮點格式都由三部分組成,包括:1個比特的符號位、若干比特的指數位、若干比特的小數位,如下圖所示:
浮點格式

C語言中 float類型(32位浮點)為例,它的符號位占 1位,指數位占 8位,小數位占 23位,如下圖所示:
C語言float類型格式

值得注意的是,
1)指數位編碼的指數以 2為底數,若要表示很小的數,例如 1/(2^n) == 2^(-n),則指數位會出現負數 (-n),那么還需要專門的符號位來表示,因此指數位是以 127為偏移的,也就是說,一個數在用浮點數來表示時,其指數位的值是實際指數值加上 127。對于 64位浮點數,它的指數位是 11個比特,以 1023為偏移。
2)浮點數的小數部分是將該浮點數表示為 2^n * 1.m后,0.m那部分的數值,也就是說,整數部分始終是 1,且被忽略了(不用保存),這樣就能省出一位來表示更高的精度。

舉例來說,
1)0.5 = 2^(-1) * 1.0,其指數位為 (-1 + 127),小數位為 0.0,其二進制是:0 01111110 00000000000000000000000,也就是 0x3F000000
2)5 = 2^(2) * 1.25,其指數位為 (2 + 127),小數位為 0.25,其二進制是:0 10000001 01000000000000000000000, 也就是 0x40A00000

測試代碼如下:

#include <stdio.h>int main(void)
{float a = 0.5;unsigned int *b = (unsigned int*)&a;printf("b = 0x%X\n", *b);a = 5;printf("b = 0x%X\n", *b);
}

程序運行結果如下:

$ gcc -o main main.c 
$ ./main 
b = 0x3F000000
b = 0x40A00000

32位浮點的指數寬度來看,理論上,它可以表示很大的數,比如:2^(128) * 1.9999999,這比我們 32位整型能表示的范圍(2^(32) - 1)大的多,但受限于浮點小數位的寬度,有些 32位整型數是無法用浮點數來表示的,也就是會出現空洞,原因是浮點數的小數部分精度有限,當小數部分比 1/(2^23)還小時,就無法準確表示該整型數,例如:2^(24) + 1這個數用 32位整型來表示是沒有問題的,但用 32位浮點來表示,則會被舍入為:2^24

測試代碼如下:

#include <stdio.h>int main(void)
{float a = 1 << 24;unsigned b = 1 << 24;printf("a = %f, b = %u\n", a, b);a += 1;b += 1;printf("a = %f, b = %u\n", a, b);return 0;
}

程序運行結果如下:

$ gcc -o main main.c
$ ./main 
a = 16777216.000000, b = 16777216
a = 16777216.000000, b = 16777217

參考資料:

  1. https://www.gnu.org/software/c-intro-and-ref/manual/html_node/Floating-Representations.html
  2. https://docs.nvidia.com/cuda/floating-point/index.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/42503.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/42503.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/42503.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

使用AOP思想實現開閉原則下的流水日志輸出

主要實現思想&#xff1a; 通過實現Convert接口來抽取公共組件&#xff0c;獲取想要的標準模型。 現在有兩個訂單場景&#xff0c;一個保存訂單&#xff0c;一個為更新訂單。構造如下的服務類&#xff1a; import org.springframework.stereotype.Service;Service public clas…

JavaScript-實例-button

1 需求 2 接口 3 點擊button跳轉到一個頁面 在HTML中&#xff0c;當你想要點擊一個按鈕并跳轉到另一個頁面時&#xff0c;通常你可以使用<a>標簽來包裹按鈕的樣式&#xff08;盡管這通常不是最佳實踐&#xff0c;因為<a>標簽是用于鏈接的&#xff0c;而<button&…

SHAP(SHapley Additive exPlanations)基于XGBoost模型的可解釋機器學習

模型可解釋性 這是一個關于錯誤解釋機器學習模型的危險以及正確解釋它的價值的故事。如果您發現諸如梯度提升機或隨機森林之類的集成樹模型的魯棒準確性很有吸引力&#xff0c;但也需要解釋它們&#xff0c;那么我希望您發現這些信息有用且有幫助。 試想一下&#xff0c;我們…

julia系列17: tsp問題代碼整理

1. 常用庫和基礎函數 這里是優化版的函數&#xff1a; using TSPLIB,LKH,Distances,PyPlot MaxNum 10000 tspreadTSPLIB(:att48) dist [round.(Int,euclidean(tsp.nodes[i,:],tsp.nodes[j,:])) for i in 1:tsp.dimension,j in 1:tsp.dimension]; pos(tsp::TSP,t::Vector{In…

Groovy中,多種循環方式

1.最常規的for循環 for (def i 0; i < 5; i) { //這個i需要聲明println "遍歷輸出${i}" }2.while循環 def j 0 while (j < 5) {println "遍歷輸出 ${j}"j }3.for in 循環 def list [0, 1, 2, 3, 4] //這個l無需聲明 for (l in list) { printl…

uniapp跨域問題解決

找到menifest文件&#xff0c;在文件的最后添加如下代碼&#xff1a; // h5 解決跨域問題"h5":{"devServer": {"proxy": {"/adminapi": {"target": "https://www.demo.com", // 目標訪問網址"changeOrigin…

數據庫的存儲引擎,數據類型,約束條件,嚴格模式

【一】存儲引擎 1.什么是存儲引擎存儲引擎可以理解為處理數據的不同方式 2.查看存儲引擎show engines; 3.須知的引擎MyISAM5.5之前版本MySQL默認的存儲引擎特點:存取數據的速度快 但是功能很少 安全性較低速度快因為自帶索引InnoDB5.5之后版本MySQL默認的存儲引擎特點:有諸多功…

工程施工合同無效但竣工交付,應當參照合同關于工程價款的約定計算折價補償款

審判實踐中&#xff0c;對于建設工程施工合同無效但工程竣工并交付使用的&#xff0c;應以何種標準計算折價補償款的問題&#xff0c;認識不一致。【法官會議意見】&#xff1a;建設工程施工合同是承包人進行工程建設、交付工作成果即建設工程并由發包人支付價款的合同。建設工…

httpd目錄顯示亂碼問題

vim /etc/httpd/conf/httpd.conf 在<Directory “/var/www/html”>下添加&#xff1a; IndexOptions CharsetUTF-8重啟httpd: systemctl restart httpd.service還是不好看&#xff0c;調整下顯示寬度&#xff0c;還是這個位置&#xff1a; <Directory “/var/www/ht…

區塊鏈論文速讀A會-ISSTA 2023(2/2)如何檢測DeFi協議中的價格操縱漏洞

Conference&#xff1a;ACM SIGSOFT International Symposium on Software Testing and Analysis (ISSTA) CCF level&#xff1a;CCF A Categories&#xff1a;Software Engineering/System Software/Programming Languages Year&#xff1a;2023 第1~5篇區塊鏈文章 請點擊此…

09視圖,觸發器,事務,存儲過程,函數,流程控制,索引,隔離機制,鎖機制,三大范式

【一】視圖 (1)視圖須知概念 1.什么是視圖&#xff1f; 視圖就是通過查詢得到一張虛擬表&#xff0c;然后保存下來&#xff0c;下次可以直接使用 2.為什么要用視圖&#xff1f; 如果要頻繁操作一張虛擬表(拼表組成)&#xff0c;就可以制作成視圖&#xff0c;后續直接操作 注意…

IDEA 創建springboot項目雜記-更新中

一、工具使用雜記 1、使用maven 創建新springboot項目時&#xff0c;因為https://start.spring.io/ 連接不上項目無法創建。直接把腳手架地址換為國內的 http://start.aliyun.com

田忌賽馬 貪心

本題是更難的那道,一場50 最低為o 第一行一個整數 &#x1d45b;n &#xff0c;表示他們各有幾匹馬&#xff08;兩人擁有的馬的數目相同&#xff09;。第二行 &#x1d45b;n 個整數&#xff0c;每個整數都代表田忌的某匹馬的速度值&#xff08;0≤0≤ 速度值 ≤100≤1…

Python】從文本字符串中提取數字、電話號碼、日期、網址的方法

關于從文本字符串中提取數字、電話號碼、日期和網址的方法&#xff1a; 提取數字&#xff1a; 在 Python 中&#xff0c;使用正則表達式 \d 來匹配數字。 \d 表示匹配一個數字字符&#xff08;0-9&#xff09;。如果要匹配連續的數字&#xff0c;可以使用 \d 。 import re def …

C++面向對象的常見面試題目(一)

1. 面向對象的三大特征 &#xff08;1&#xff09;封裝&#xff1a;隱藏對象的內部狀態&#xff0c;只暴露必要的接口。 #include <iostream> #include <string>// 定義一個簡單的類 Person class Person { private: // 私有成員&#xff0c;外部不可直接訪問std…

Mac OS ssh 連接提示 Permission denied (publickey)

這錯誤有點奇葩&#xff0c;MacBook的IDE(vscode和pycharm)遠程都連不上&#xff0c;terminal能連上&#xff0c;windows的pycharm能連上&#xff0c;見鬼了&#xff0c;所以肯定不是秘鑰的問題了&#xff0c;查了好久竟然發現是權限的問題。。 chmod 400 ~/.ssh/id_rsa http…

華為機試HJ37統計每個月兔子的總數

華為機試HJ37統計每個月兔子的總數 題目&#xff1a; 想法&#xff1a; 上述題目實際是一個斐波那契數列&#xff0c;利用斐波那契數列對問題進行求解 input_number int(input())def fib(n):if n < 2:return 1else:n_1 1n_2 1count 2while count < n:n_1, n_2 n_…

【Android】【多屏】多屏異顯異觸調試技巧總結

這里寫目錄標題 如何獲取多屏IDs獲取多屏的size/density如何啟動應用到指定DisplayId多屏截屏/錄屏screencapscreenrecord發送按鍵到指定DisplayId 如何獲取多屏IDs dumpsys display | grep mDisplayIdtrinket:/ # dumpsys display | grep mDisplayIdmDisplayId0mDisplayId2 t…

【AI資訊】可以媲美GPT-SoVITS的低顯存開源文本轉語音模型Fish Speech

Fish Speech是一款由fishaudio開發的全新文本轉語音工具&#xff0c;支持中英日三種語言&#xff0c;語音處理接近人類水平&#xff0c;使用Flash-Attn算法處理大規模數據&#xff0c;提供高效、準確、穩定的TTS體驗。 Fish Audio

區塊鏈技術的應用場景和優勢。

區塊鏈技術具有廣泛的應用場景和優勢。 區塊鏈技術的應用場景&#xff1a; 1. 金融服務&#xff1a;區塊鏈可用于支付、跨境匯款、借貸和結算等金融服務&#xff0c;提高交易效率、降低成本并增強安全性。 2. 物聯網&#xff08;IoT&#xff09;&#xff1a;區塊鏈可以用于物…