單片機的一個浮點數(shù)一般在KeilC51中是以4字節(jié)形式存儲的,格式嚴(yán)格遵循IEEE-754標(biāo)準(zhǔn)。在單片機二進(jìn)制數(shù)據(jù)中,浮點數(shù)用兩個部分來表示,基C為2,E為階碼,M為尾數(shù),E的保存形式是一個0~255的8位值,指數(shù)的實際表示值是保存值減去127,范圍在-127~+128的數(shù),尾數(shù)是一個24位值,換算7個十進(jìn)制數(shù),最高位通常是1,符號位表示浮點數(shù)的正負(fù)。
現(xiàn)在看怎樣顯示一個浮點數(shù),由于浮點數(shù)的尾數(shù)是24位,最高可以表達(dá)的整數(shù)值為16777215,用科學(xué)計數(shù)法表示時整數(shù)部分占據(jù)1位,小數(shù)部分就可以有6位,我們將浮點數(shù)的尾數(shù)放在長整形數(shù)據(jù)longint中保存,階碼可以在int型數(shù)據(jù)中保存。此處我們用C程序來實現(xiàn)顯示一個浮點數(shù)的功能。
(1)浮點數(shù)顯示子函數(shù)。
}}
(2)顯示十進(jìn)制尾數(shù)和階的子函數(shù)。
在大多數(shù)的單片機應(yīng)用系統(tǒng)中都不能離開數(shù)值計算,最基本的數(shù)值運算為四則運算,單片機中的數(shù)都是以二進(jìn)制形式表示的,二進(jìn)制的算法有很多,其中最基本的是定點制和浮點制,以上介紹了浮點數(shù)在單片機中的表示方式和匯編子程序,浮點數(shù)比定點數(shù)加減法要困難,但是克服了定點數(shù)表示范圍小的問題,總之定點數(shù)和浮點數(shù)各有各得的特點,讀者可以在實際運用中加以優(yōu)化運用。
-
單片機
+關(guān)注
關(guān)注
6071文章
45259瀏覽量
660125
原文標(biāo)題:51單片機執(zhí)行指令的過程
文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
大彩講堂:VisualHMI-LUA教程-獲取設(shè)置單精度浮點數(shù)函數(shù)的應(yīng)用

求助,關(guān)于使用sprintf函數(shù)格式化浮點數(shù)的安全問題求解
FPGA定點和浮點數(shù)學(xué)運算實例對比

想在bsp工程打印浮點數(shù),結(jié)果找不到rt_vsnprintf_full軟件包,怎么解決?
PRINTF函數(shù)無法打印出浮點數(shù)內(nèi)容是為什么?
cubeide中浮點函數(shù)返回值錯誤是怎么回事?
設(shè)計了一個基于浮點數(shù)運算的協(xié)處理器,使用C語言編程時沒法輸入float型數(shù)據(jù),請問有哪些部分需要修改?
labview數(shù)據(jù)類型與PLC 數(shù)據(jù)類型之間的轉(zhuǎn)換(來自于寫入浮點數(shù)到匯川 PLC中的數(shù)據(jù)轉(zhuǎn)換關(guān)鍵的修改)
西門子TIA Portal如何比較兩個浮點數(shù)相等

ADS1282采集到的數(shù)據(jù)傳到PC上應(yīng)該怎么轉(zhuǎn)為浮點數(shù)?
基于FPGA的數(shù)字信號處理——浮點數(shù)

評論