C語言菜鳥基礎(chǔ)教程之單精度浮點(diǎn)數(shù)與雙精度浮點(diǎn)數(shù)
上節(jié)課 簡(jiǎn)單介紹了浮點(diǎn)數(shù)。計(jì)算機(jī)程序中的浮點(diǎn)數(shù)分為單精度浮點(diǎn)數(shù)和雙精度浮點(diǎn)數(shù)。
單精度和雙精度精確的范圍不一樣。
計(jì)算機(jī)里的最基本的存儲(chǔ)單位用位(bit)來表示。bit只能用來存儲(chǔ)0或1。
稍大一點(diǎn)的單位是字節(jié)(Byte,簡(jiǎn)寫為B)。
再大一級(jí)的是千字節(jié)(kilo Bytes),用k來表示。
再大一級(jí)的單位是兆字節(jié)(Mega Bytes),用M來表示。一張照片的大小通常為1~3M。
再大一級(jí)的單位為G。一部高清電影的大小通常為1~2G。
再大一級(jí)的單位為T。
換算關(guān)系為:
1B = 8bit
1k = 1024B = 2^10 B
1M = 1024k = 2^20 B
1G = 1024M = 2^30 B
1T = 1024G = 2^40 B
單精度(float)在計(jì)算機(jī)中存儲(chǔ)占用4字節(jié),32位,有效位數(shù)為7位(6位小數(shù)+小數(shù)點(diǎn))。
雙精度(double)在計(jì)算機(jī)中存儲(chǔ)占用8字節(jié),64位,有效位數(shù)為16位(15位小數(shù)+小數(shù)點(diǎn))。
不管是float還是double,在計(jì)算機(jī)中的存儲(chǔ)都遵循IEEE規(guī)范,使用二進(jìn)制科學(xué)計(jì)數(shù)法,都包含三個(gè)部分:符號(hào)位、指數(shù)位和尾數(shù)部分。其中float的符號(hào)位、指數(shù)位(即整數(shù)部分)、尾數(shù)部分分別為1, 8, 23。雙精度則分別為1, 11, 52。
float
double
精度主要取決于尾數(shù)部分的位數(shù),float為23位,最小為2的-23次方,約等于1.19乘以10的-7次方,所以float小數(shù)部分只能精確到后面6位,加上小數(shù)點(diǎn)算做一位,即有效數(shù)字為7位。
類似,double 尾數(shù)部分52位,最小為2的-52次方,約為2.22乘以10的-16次方,所以精確到小數(shù)點(diǎn)后15位,有效位數(shù)為16位。
程序驗(yàn)證:
#include <stdio.h> int main() { float a = 1.123456789; printf("a = %20.9f\n", a); double b = 2.123456789; printf("b = %20.9f\n", b); return 0; }
注意:這里%20.9f表示浮點(diǎn)數(shù)總共有20位,其中小數(shù)占9位。不足20位的部分,左側(cè)用空格來填充。
運(yùn)行結(jié)果:
a = 1.123456836 b = 2.123456789
從運(yùn)行結(jié)果可以看出,單精度浮點(diǎn)數(shù)小數(shù)部分只有前6位是準(zhǔn)確的,后三位是不準(zhǔn)確的。雙精度小數(shù)部分9位都是準(zhǔn)確的。
欄 目:C語言
本文標(biāo)題:C語言菜鳥基礎(chǔ)教程之單精度浮點(diǎn)數(shù)與雙精度浮點(diǎn)數(shù)
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1142.html
您可能感興趣的文章
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用函數(shù)刪除字符
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)式函數(shù)庫
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言中對(duì)數(shù)函數(shù)的表達(dá)式 c語言中對(duì)數(shù)怎么表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段函數(shù)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排序法函數(shù)
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段函數(shù)
- 04-02C語言中怎么打出三角函數(shù) c語言中怎么打出三角函數(shù)的值
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求階乘


閱讀排行
- 1C語言 while語句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對(duì)數(shù)函數(shù)的表達(dá)式 c語言中對(duì)
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機(jī)閱讀
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 04-02jquery與jsp,用jquery
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 01-10C#中split用法實(shí)例總結(jié)