久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2864|回復: 15
打印 上一主題 下一主題
收起左側(cè)

求教浮點數(shù)的十進制轉(zhuǎn)十六進制原理和代碼

  [復制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:1041056 發(fā)表于 2022-8-4 21:02 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
50黑幣
eg:1對應3F800000
100對應42C80000

十進制是double類型,十六進制是字符
在線轉(zhuǎn)換鏈接如下,可供驗證
ToolTT在線工具箱

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩
回復

使用道具 舉報

沙發(fā)
ID:584814 發(fā)表于 2022-8-5 08:14 | 只看該作者
浮點數(shù)的十進制轉(zhuǎn)十六進制原理可百度
浮點數(shù)的十進制轉(zhuǎn)十六進制代碼可百度
回答完畢
回復

使用道具 舉報

板凳
ID:123289 發(fā)表于 2022-8-5 08:20 | 只看該作者
計算機只認識二進制數(shù),它不認識【負】、【小數(shù)點】。怎么辦呢?就人為規(guī)定一下。
規(guī)定,也就是協(xié)議。只要“計算機”(其實是使用的人)能遵守這個協(xié)議,也就認識【負】、【小數(shù)點】了。
顯然,協(xié)議規(guī)定不同,負數(shù)、小數(shù)的表示方式也就不同(建議在一個系統(tǒng)中,用同樣的協(xié)議)。
就樓主的問題,稍候給出兩種常用的浮點數(shù)的表示方式。
關(guān)鍵點:負號在哪?小數(shù)點在哪?
回復

使用道具 舉報

地板
ID:883242 發(fā)表于 2022-8-5 08:44 | 只看該作者
你只管用就可以了,無需知道具體代碼。但凡是支持浮點數(shù),包括float和/或double的編譯器,必定在函數(shù)庫里面實現(xiàn)了你所需要的功能。
回復

使用道具 舉報

5#
ID:401564 發(fā)表于 2022-8-5 08:45 | 只看該作者
原理就是IEEE規(guī)定的數(shù)據(jù)存放格式,我到現(xiàn)在都不知道怎么轉(zhuǎn)換
但這并不影響我用C語言寫程序
我不知道你要知道浮點型轉(zhuǎn)換成16進制有什么用?
回復

使用道具 舉報

6#
ID:123289 發(fā)表于 2022-8-5 09:01 | 只看該作者
兩種四個字節(jié)組成的浮點數(shù):(一般夠用了,如果要求特別,當然可以增加字節(jié)數(shù),重新定義)
先給出四個字節(jié):通常從存放的位置看,從低地址至高地址(反之只有你能說清楚也可以),A1,A2,A3,A4。
再細分:A1.0-A1.7,A2.0-......,A4.0-A4.7。
為了方便說明重新定義一下:A4.7=D31,A4.6=D30....,A1.7=D7,......,A1.0=D0,這樣就得到一個數(shù):D31,D30,......,D0。
浮點數(shù)的第一種表示方式:階碼=D30~D23,符號=D31,底數(shù)=1(最高位隱1)+D22~D0 1=3F800000,2=40000000  【我在STM8用過】
浮點數(shù)的第二種表示方式:階碼=D31~D24,符號=D23,底數(shù)=1(最高位隱1)+D22~D0 1=7F000000,2=80000000  【我在51中用過】
不同的編譯平臺或軟件,可能采用不同的表示方式,亦或是有人故意的。不過不用擔心,同一個平臺是不可能混淆的。
回復

使用道具 舉報

7#
ID:844772 發(fā)表于 2022-8-5 09:44 | 只看該作者
我試試說一下,不講單精度了,只說你要的雙精度,雙精度浮點是8字節(jié),64位,最高位是符號位,顯示正負,接著11位是指數(shù)位,剩余52位是小數(shù)位。它的保存是用科學計數(shù)法保存數(shù)值,也就是說任何數(shù)都以,二進制的小數(shù)和二進制的指數(shù)表示,例子看你的鏈接就明白。另外,指數(shù)也有正負,所以指數(shù)統(tǒng)一加偏移量1023后存儲。別看說的麻煩,程序及其簡單,因為使用強制類轉(zhuǎn)換,一句搞掂。
double fff=1.0;  //
unsigned char *htext=(unsigned char *)& fff; //其實就這一句就轉(zhuǎn)成十六進制了。
//下面驗證一下 htext必然是八字節(jié)啊,只是有的系統(tǒng)是從小到大排列
for ( char i=0;i<8;i++)
  printf (" %02x",htext[7-i]);

回復

使用道具 舉報

8#
ID:123289 發(fā)表于 2022-8-5 09:52 | 只看該作者
本帖最后由 yzwzfyz 于 2022-8-5 10:08 編輯

解碼:浮點數(shù)的值 = [符號]底數(shù) * 2^(階碼-(7FH+23)) = [符號]底數(shù) * 2^(階碼-96H)
23:(這里用10進制寫是為了方便您理解),因為底數(shù)有24位,其最高位的1就代表2^23。
階碼:小數(shù)點的位置。
7FH:(這里用16進制寫是突出一個字節(jié)0-FFH的中位數(shù)7FH,用10進制寫成127也一樣),這樣階碼表示的小數(shù)點位置向左向右有127位移動空間。

符號:占1位,1為負數(shù),0為正數(shù)。
階碼:占8位,無符號數(shù)=0-FFH(0-255),理解為方次,階碼=75,就表示:2的75次方。也可以理解為小數(shù)點的位置。
底數(shù):24位,正常的數(shù),補碼,只剩余23位:D22-D0,何來24位呢?
特別注意:強制規(guī)定(也是妙處),底數(shù)雖然沒有D23,但就是認為有D23,且D23=1。D23是隱含1!
如果實際中D23偏偏是0呢?比如底數(shù)據(jù)=0111010……(如果實際底數(shù)首位D23=0)。
沒有關(guān)系,通過將底數(shù)左移,必能使首位D23=1,本例左移一位即變成111010……,D23就=1了,再將階碼減去左移的位數(shù),本例階碼-1就平衡掉底數(shù)的左移了。
回復

使用道具 舉報

9#
ID:123289 發(fā)表于 2022-8-5 10:28 | 只看該作者
本帖最后由 yzwzfyz 于 2022-8-5 14:39 編輯

1對應3F800000
100對應42C80000
浮點數(shù)格式:階碼=D30~D23,符號=D31,底數(shù)=1(最高位隱1)+D22~D0

解:3F800000 = 00111111,10000000,0000H
首位:D31 = 0,正數(shù)。
階碼:D30-D23 = 0111111,1 = 7FH
底數(shù):D22-D0 = 0000000,0000H,D23強制隱含=1,即底數(shù) = 10000000,0000H = 800000H
解碼:3F800000的值 = 800000H * 2^(7FH-(7FH+23)) = 800000H * 2^(-23) = 1

解:42C80000 = 01000010,11001000,0000H
首位:D31 = 0,正數(shù)。
階碼:D30-D23 = 1000010,1 = 85H
底數(shù):D22-D0 = 1001000,0000H,D23強制隱含=1,即底數(shù) = 11001000,0000H = C80000H
解碼:42C80000的值 = C80000H * 2^(85H-96H) = 13107200 * 2^(-17) = 100
回復

使用道具 舉報

10#
ID:123289 發(fā)表于 2022-8-5 11:26 | 只看該作者
浮點數(shù)的十進制轉(zhuǎn)十六進制原理:
第一、這里有個誤區(qū):浮點數(shù)的十進制?
浮點數(shù)在計算機的內(nèi)存里,幾乎都是以二進制格式存儲的,如果你要強行將其轉(zhuǎn)成10進制,那么又有新的問題出現(xiàn),10進制的表達方式是什么?
如123456,可以用6個字節(jié)表示:01H,02H,03H,04H,05H,06H。也可以用3個字節(jié)表示,即BCD碼:12H,34H,56H。
不懂匯編語言,是不太好理解的。
第二、如果浮點數(shù)有小數(shù),在16進行中如何表示小數(shù)呢?如:3.14。
這個問題涉及浮點數(shù)與定點數(shù)。比如,用4個字節(jié)來表示,前三個字節(jié)表示整數(shù),后一個字節(jié)表示小數(shù)(這叫定點數(shù),規(guī)定了小數(shù)點的位置,看似簡單,卻有難點。。
難點1:整數(shù)有限制,不能大于FFFFFFH=16777215,否則溢出,這還好說好解決。
難點2:更麻煩的是,小數(shù)0.14,你幾乎想象不出它的如何寫!
以3.5為例:3.5可以寫成:00H,00H,03H,80H。
能不能寫成:00H,00H,03H,05H呢?不能!你做個3.5+3.5就知道為何,16進制的0.5為何要寫成80H而不是05H了。
討厭的小數(shù)部分0.14如何用16進行表達,就不在這里繁瑣了,還是那句話:不懂匯編語言,是不太好理解的。(3.14在這里只能近似地寫成00H,00H,03H,24H,而不是00H,00H,03H,14H,小數(shù)部分要先乘以256,然后而存入整數(shù)部分)
樓主要:【求教浮點數(shù)的十進制轉(zhuǎn)十六進制原理和代碼】,建議先學通匯編。
否則:就聽取樓上其它人的建議吧。
不是不講給你聽,而是比較復雜,你也缺一些課,不易簡單地就能讓你明白。
回復

使用道具 舉報

11#
ID:57657 發(fā)表于 2022-8-5 12:23 | 只看該作者
Y_G_G 發(fā)表于 2022-8-5 08:45
原理就是IEEE規(guī)定的數(shù)據(jù)存放格式,我到現(xiàn)在都不知道怎么轉(zhuǎn)換
但這并不影響我用C語言寫程序
我不知道你要知 ...

浮點數(shù)的傳輸、存儲可以用union結(jié)構(gòu)進行轉(zhuǎn)換。
回復

使用道具 舉報

12#
ID:1034262 發(fā)表于 2022-8-5 15:07 | 只看該作者
不是編譯器處理的嗎?不需要自己寫程序的。
回復

使用道具 舉報

13#
ID:462768 發(fā)表于 2022-8-5 17:29 | 只看該作者
這種底層的東西,禁止轉(zhuǎn)換,編程入門書上就有
回復

使用道具 舉報

14#
ID:139866 發(fā)表于 2022-8-9 13:48 | 只看該作者
m2006410 發(fā)表于 2022-8-5 17:29
這種底層的東西,禁止轉(zhuǎn)換,編程入門書上就有

你也說了,是入門書,而且我估計不是嵌入式入門書
回復

使用道具 舉報

15#
ID:593706 發(fā)表于 2022-8-9 17:26 | 只看該作者
樓主詢問的是用單片機轉(zhuǎn)換,還是用計算機轉(zhuǎn)換呀?如果是用計算機進行轉(zhuǎn)換,我的貼子里有現(xiàn)成的轉(zhuǎn)換程序,如果是用單片機轉(zhuǎn)換,稍微復雜一些,單片機轉(zhuǎn)換主要有查表法和數(shù)組循環(huán)計算法
回復

使用道具 舉報

16#
ID:844772 發(fā)表于 2022-8-10 22:13 | 只看該作者
m2006410 發(fā)表于 2022-8-5 17:29
這種底層的東西,禁止轉(zhuǎn)換,編程入門書上就有

打錯字了吧,是徑直轉(zhuǎn)換,還是個經(jīng)典程序
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产欧美在线视频 | 日韩毛片| 中文字幕人成乱码在线观看 | 成人欧美一区二区三区在线播放 | 国产在线一区二区三区 | 久久久久久久久久久蜜桃 | 玖玖国产| 欧美激情久久久 | 91精品一区二区三区久久久久 | 一区二区免费在线 | 亚洲国产精品一区二区久久 | 亚洲成人a v | 欧美二三区 | 国产69精品久久99不卡免费版 | 范冰冰一级做a爰片久久毛片 | 国产精品国产三级国产aⅴ无密码 | 欧美v在线观看 | 午夜影视 | 亚洲精品在 | 久久久久久亚洲精品 | 四虎影院久久 | 欧美视频日韩 | 国产伊人精品 | 精品国产伦一区二区三区观看体验 | 色吧色综合 | aaa在线| 久久香蕉精品视频 | 黄色大片在线播放 | 99久久精品视频免费 | 美女人人操 | 中文字幕 在线观看 | 欧美日韩网站 | 国产午夜高清 | 日韩不卡在线观看 | 久久国产精品99久久久久 | 欧美 日韩 亚洲91麻豆精品 | 亚洲欧美另类在线观看 | 精品区一区二区 | 久久久婷婷 | 精品成人免费一区二区在线播放 | 国产99热在线 |