A. 51單片機數據處理問題。串口接收到浮點數(如6.228)存在數組hs[5]中
存在數組中的格式是否是ACSII碼格式取決於發送端的格式,要統一。如果發送端發送的是ASCII碼,你就可以這樣存,但計算時還得進行轉換。如果發送端發送的就是浮點數,你接受也可存放數組,使用時按浮點數規定格式使用就是了。
將這個浮點數乘以1000然後除以200000,直接除以200就完了。
B. 51單片機串口接收數組數據並存儲
在使用51單片機進行串口接收數組數據時,可以採用開辟一個接收緩沖區的方法來存儲數據。具體代碼如下:
首先,定義一個數組變數和一個計數器變數:
#include
#define uchar unsigned char
uchar buf[16], num;
接著,設置中斷服務函數,用於處理串口接收到的數據:
void ser_isr() interrupt 4 {
if(RI) {
RI = 0;
buf[num] = SBUF;
num++;
num &= 0x0f;
}
}
在主函數中,進行初始化設置:
TMOD = 0x20;
SCON = 0x50;
TH1 = TL1 = 0xfd;
TR1 = 1;
ES = 1;
EA = 1;
while(1);
其中,TMOD、SCON、TH1、TL1、TR1、ES、EA是用於配置單片機相關寄存器的參數。
TMOD寄存器用於設置定時/計數器的工作模式。
SCON寄存器用於設置串口通信模式,0x50表示模式1,8位數據位,1位停止位,偶校驗。
TH1和TL1寄存器用於設置定時/計數器1的初始值,0xfd表示設置為定時模式,定時周期為64ms。
TR1用於啟動定時/計數器1。
ES用於使能串口中斷。
EA用於使能總中斷。
這樣的配置能夠確保單片機正確接收並存儲串口數據。
需要注意的是,num變數的更新方式可以防止數組越界,通過與0x0f進行按位與操作,可以確保num的值始終在0到15之間。
整個程序通過不斷循環運行,等待新的串口數據到來,並將其存儲到數組buf中。
這種方式適用於需要接收和處理一定數量串口數據的應用場景。
在實際應用中,可以根據具體需求調整數組buf的大小,以及配置定時/計數器的值,以適應不同的通信速率和數據處理需求。
C. 51單片機串口通訊,在接收一端某處我用xdata就很正常,用data或idata程序就不太穩定請問問題可能出在哪
你使用xdata區存放接收的數據時表現正常,但在使用data或idata區時程序不穩定,這可能是因為內存不足。51單片機的內存僅有128位元組,包括工作寄存器區和堆棧區,如果存放的數據較多,很容易導致內存溢出。
假設你的程序佔用105個位元組,那麼留給數據存儲的空間就非常有限了。如果你使用的是擴展外部數據存儲器,那麼idata區可以擴展到256位元組。將接收數組放在0x80區,可以有效利用這部分空間。例如,聲明變數如下:
unsigned char idata buf[80] _at_ 0x80;
這樣,可以確保你的數據不會溢出,並且程序運行更加穩定。
在工程設置中選擇AT89C52單片機型號,可以增加idata區的大小,從而提供更多的存儲空間。同時,確保程序邏輯合理,避免不必要的變數和函數調用,以減少內存佔用。
綜上所述,內存不足是導致程序不穩定的主要原因。通過合理分配內存空間,優化程序邏輯,可以有效解決這一問題。