單片機(jī)的一個(gè)浮點(diǎn)數(shù)一般在KeilC51中是以4字節(jié)形式存儲(chǔ)的,格式嚴(yán)格遵循IEEE-754標(biāo)準(zhǔn)。在單片機(jī)二進(jìn)制數(shù)據(jù)中,浮點(diǎn)數(shù)用兩個(gè)部分來(lái)表示,基C為2,E為階碼,M為尾數(shù),E的保存形式是一個(gè)0~255的8位值,指數(shù)的實(shí)際表示值是保存值減去127,范圍在-127~+128的數(shù),尾數(shù)是一個(gè)24位值,換算7個(gè)十進(jìn)制數(shù),最高位通常是1,符號(hào)位表示浮點(diǎn)數(shù)的正負(fù)。
現(xiàn)在看怎樣顯示一個(gè)浮點(diǎn)數(shù),由于浮點(diǎn)數(shù)的尾數(shù)是24位,最高可以表達(dá)的整數(shù)值為16777215,用科學(xué)計(jì)數(shù)法表示時(shí)整數(shù)部分占據(jù)1位,小數(shù)部分就可以有6位,我們將浮點(diǎn)數(shù)的尾數(shù)放在長(zhǎng)整形數(shù)據(jù)longint中保存,階碼可以在int型數(shù)據(jù)中保存。此處我們用C程序來(lái)實(shí)現(xiàn)顯示一個(gè)浮點(diǎn)數(shù)的功能。
(1)浮點(diǎn)數(shù)顯示子函數(shù)。
}}
(2)顯示十進(jìn)制尾數(shù)和階的子函數(shù)。
在大多數(shù)的單片機(jī)應(yīng)用系統(tǒng)中都不能離開(kāi)數(shù)值計(jì)算,最基本的數(shù)值運(yùn)算為四則運(yùn)算,單片機(jī)中的數(shù)都是以二進(jìn)制形式表示的,二進(jìn)制的算法有很多,其中最基本的是定點(diǎn)制和浮點(diǎn)制,以上介紹了浮點(diǎn)數(shù)在單片機(jī)中的表示方式和匯編子程序,浮點(diǎn)數(shù)比定點(diǎn)數(shù)加減法要困難,但是克服了定點(diǎn)數(shù)表示范圍小的問(wèn)題,總之定點(diǎn)數(shù)和浮點(diǎn)數(shù)各有各得的特點(diǎn),讀者可以在實(shí)際運(yùn)用中加以?xún)?yōu)化運(yùn)用。
-
單片機(jī)
+關(guān)注
關(guān)注
6061文章
44838瀏覽量
645309
原文標(biāo)題:51單片機(jī)執(zhí)行指令的過(guò)程
文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
PRINTF函數(shù)無(wú)法打印出浮點(diǎn)數(shù)內(nèi)容是為什么?
設(shè)計(jì)了一個(gè)基于浮點(diǎn)數(shù)運(yùn)算的協(xié)處理器,使用C語(yǔ)言編程時(shí)沒(méi)法輸入float型數(shù)據(jù),請(qǐng)問(wèn)有哪些部分需要修改?
labview寫(xiě)入浮點(diǎn)數(shù)到匯川 PLC中的數(shù)據(jù)轉(zhuǎn)換關(guān)鍵
西門(mén)子TIA Portal如何比較兩個(gè)浮點(diǎn)數(shù)相等

ADS1282采集到的數(shù)據(jù)傳到PC上應(yīng)該怎么轉(zhuǎn)為浮點(diǎn)數(shù)?
TLV320AIC3106音頻芯片怎么發(fā)送、接收浮點(diǎn)數(shù)呢?
labview中浮點(diǎn)數(shù)與十六進(jìn)制字符串相互轉(zhuǎn)化
TMS320C6745浮點(diǎn)數(shù)字信號(hào)處理器技術(shù)簡(jiǎn)介

分享在arduino 單片機(jī)中浮點(diǎn)數(shù)轉(zhuǎn)換位數(shù)不夠,精度丟失的解決辦法
請(qǐng)問(wèn)AURIX TC3xx tricore架構(gòu)下浮點(diǎn)運(yùn)算和將浮點(diǎn)數(shù)小數(shù)點(diǎn)去掉變成整數(shù)來(lái)計(jì)算哪種方式更加節(jié)省算力?
TMS320C6711D浮點(diǎn)數(shù)字信號(hào)處理器數(shù)據(jù)表

評(píng)論