在8位單片機中沒有16位數的操作指令,所有的int型數據都要通過兩個字節分開操作,使用的方法不用,生成的代碼也不相同,當然效率也不一樣,通過指針對16位數進行操作可以得到高效的代碼。
比如通過串行口接收數據,或者從串行的EEPROM中讀取的數據,或者從大于8位的A/D讀取的數據,由于8位單片機的數據線是8位的,高于8位的數據都要分成兩個字節分別讀取,然后寫入到RAM中去再進行計算,或者把16位的int型數據從RAM中讀出再分別把高低字節存到EEPROM或者送到D/A,或者通過串行口發送出去,方法有很多種,下面用多種方法進行實現該操作,這里只演示寫入到16位的情況,讀取的情況非常相似,不贅述。
(1)使用聯合 (union)
typedef union{unsigned int i;unsigned char c[2];}u_int;unsigned char dH = 0x11, dL=0x22;unsigned int d;u_int ud;ud.c[0] = dH;ud.c[1] = dL;d = ud.i;此時d = 0x1122;
(2) 使用移位指令
數據定義與前面相同d = ((unsigned int)dH) 或者d = dH;d d |= dL; // or: d = d | dL; 后者編譯的代碼可能不是最簡的
(3)使用指針
unsigned char *cptr;cptr = (unsigned char*)(&d);cptr[0] = dH;cptr[1] = dL;
(4)強制指針類型轉換
*((unsigned char*)(&d)) = dH;*((unsigned char*)(&d)+1) = dL;或((unsigned char*)(&d))[0] = dH;((unsigned char*)(&d))[1] = dL;
這兩種方式看似相同但由Keil編譯出的代碼是不用的,前都有一次加法運算,而后者沒有,后者生成的代碼更簡潔,這種方式與用聯合成生的代碼是完全一樣的。
在這幾種方法中第(1)與第(4)的第二種生成的代碼是最乘潔的,是推薦使用的,從軟件工程的角度出發,推薦使用方法(1),這樣沒有強制類型轉換,沒有用到指針,更不容易出錯。從書寫的代碼來講,第(4)的第二種方法是最好的,代碼簡潔而且效率最高,但語法有點兒復雜。
-
單片機
+關注
關注
6067文章
44960瀏覽量
648754 -
串行接口
+關注
關注
3文章
384瀏覽量
43249 -
數據轉換
+關注
關注
0文章
90瀏覽量
18241 -
指針
+關注
關注
1文章
484瀏覽量
71096
原文標題:8位單片機操作16位INT型數據的方法你想到了幾種?
文章出處:【微信號:Mouser-Community,微信公眾號:貿澤電子設計圈】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
51單片機編寫的6位數顯頻率計數器
[轉載]Freescalenbsp;16位單片機…
使用51單片機把4位16進制數轉成10進制數的方法和程序免費下載

使用單片機實現CC4021串行輸入8-16位數據信號的仿真文件
8位、16位、32位單片機中的“XX位”指什么?

8位、16位、32位單片機(MCU)

評論