嵌入式系統(tǒng)的串口數(shù)據(jù)傳輸都是以字節(jié)為單位,但是有些特殊的數(shù)據(jù)類型,比如浮點型float a=231.5,在內(nèi)存是如何表示的呢?
我們知道浮點型float數(shù)據(jù)類型占用4個字節(jié),實際上在內(nèi)存當中a=0x43678000,只是嵌入式芯片訪問a時,知道a是浮點型數(shù)據(jù),所以一次性讀取4個字節(jié),而且也按照浮點型的數(shù)據(jù)表示規(guī)定,將a轉換為十進制的可讀數(shù)據(jù)231.5。
如果我們從串口接收到4個字節(jié)數(shù)據(jù){0x43,0x67,0x80,0x00},如何把這4個字節(jié)的數(shù)據(jù)轉換為float型呢?
直接令float a=0x43678000這是不行的(不信的讀者可以自行驗證),這就是串口通訊當中經(jīng)常遇到的問題,如果數(shù)據(jù)傳輸中包括了浮點型數(shù)據(jù),在這里我們可以通過共用體或者結構體來解決。
對于共用體:
typedefunion { floatf; unsignedchars[4]; }Union_test;
f的4個字節(jié)和s[4]的4個字節(jié)是共用一個區(qū)域,如果我們令f=231.5,然后通過VS的監(jiān)視窗查看s[4]的數(shù)值,下面是測試程序:
#include
監(jiān)視結果如下所示:

我們同樣適用結構體做了相同的實驗,將數(shù)組s[4]={0x00,0x80,0x67,0x43}的首地址s[0]強制轉換賦值給結構體z,最后打印輸出的結果也是231.5
這里我們看到原本應該是0x4367_8000的數(shù)據(jù)實際存儲的時候變成了00H 80H 67H 43H,這是因為計算機系統(tǒng)使用了小端存儲,什么是小端存儲呢?
我們都知道,對于一個超過一個字節(jié)的數(shù)據(jù),其在計算機中的存儲需要跨越字節(jié)。某些機器選擇在存儲器中按照從最低為有效字節(jié)到最高有效字節(jié)的順序存儲對象,而另一些機器則按照從最高為有效字節(jié)到到最低為有效字節(jié)的順序存儲,前一種存儲方式被稱為小端存儲,后一種方式被稱為大端存儲。
舉個例子,對于十六進制數(shù)0x01234567,其字節(jié)的存儲順序便依賴于機器,如下:

我們可以通過下面的函數(shù)測試是大端存儲還是小端存儲:
voidtest(void) { inta=1; unsignedchar*start=&a; if(*start==1) printf("小端存儲"); elseif(*start==0) printf("大端存儲"); }
審核編輯:黃飛
-
嵌入式系統(tǒng)
+關注
關注
41文章
3831瀏覽量
133906 -
數(shù)據(jù)傳輸
+關注
關注
9文章
2230瀏覽量
67750 -
內(nèi)存
+關注
關注
9文章
3238瀏覽量
76526 -
串口
+關注
關注
15文章
1627瀏覽量
83392
原文標題:串口數(shù)據(jù)傳輸當中的共用體和結構體轉換
文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關注!文章轉載請注明出處。
發(fā)布評論請先 登錄
C語言-枚舉、共用體
socket 傳輸結構體 省去字符與數(shù)據(jù)的轉換
模擬數(shù)字轉換的數(shù)據(jù)傳輸
stm32數(shù)據(jù)傳輸的相關資料分享
數(shù)據(jù)傳輸速率是什么意思
LabVIEW的串口轉WiFi數(shù)據(jù)傳輸實現(xiàn)方法
共用體和結構體的區(qū)別
C語言程序設計教程之結構體與共用體的詳細資料說明
串口數(shù)據(jù)傳輸中的共用體和結構體如何轉換?
串口傳輸數(shù)據(jù)時,結構體如何轉換?
串口數(shù)據(jù)傳輸共用體與結構體之間的轉換技巧
評論