給大家看下最全串口實驗
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)
51hei.png (20.47 KB, 下載次數: 77)
下載附件
2020-6-10 18:49 上傳
單片機源程序如下:
- #include <reg51.h>
- sbit p1_0 = P1^0;
- //初始化串口 (設置串口,開啟串口中斷)
- void init_uart(void)
- {
- SCON = 0x50; // SCON: 方式 1, 8-bit, 允許接收數據
- TMOD |= 0x20; // TMOD: 設置定時器1工作在方式2, 8-bit 自動重裝
- TH1 = 0xFD; // TH1: 初始值為0xFD 波特率:9600 晶振頻率:11.0592MHz
- TL1 = 0x0;
- TR1 = 1; // TR1: 開啟定時器1
- EA = 1; //打開總中斷
- ES = 1; //打開串口中斷
- }
-
- // 發送一個字節數據
- void uart_send_byte(unsigned char dat)
- {
- SBUF = dat; // 將數據送到發送緩沖寄存器SBUF,一位一位的發送
- while(!TI); // 等待發送完畢 (發送完畢TI硬件置1)
- TI = 0;// 將TI清零,表示可以發送下一字節數據。
- }
- // 發送字符串
- void uart_send_str(unsigned char *s)
- {
- while(*s != '\0')// '\0':字符串結束標志
- {
- uart_send_byte(*s);// 發送1個字節數據,1個字符占8位,1字節
- s++;// 指向下一個字符
- }
- }
- // 串口中斷處理函數 (串口接收到數據,發送數據完畢都可以引起串口中斷)
- void uart_interrupt(void) interrupt 4 //也叫串行中斷服務程序
- {
- unsigned char recv_data;// 用來存放接收到的數據
- unsigned char send_data[] = "I received.\n";// 要發送的信息
-
- if(RI) //接收數據(1字節)完畢,RI會被硬件置1
- {
- RI = 0; // 將 接收中斷標志位 清零(讓串口可以繼續接收數據)
- recv_data = SBUF; //讀取接收到的數據,并存放到data
-
-
- if(recv_data == '1')//如果收到的字符是'0',就讓燈滅
- {
- p1_0 = 0;// p1.0引腳低電平,LED燈亮
- }
- else
- {
- p1_0 = 1;// p1.0引腳高電平,LED燈滅
- }
- uart_send_str(send_data); //收到數據之后,發送字符串"I received."給對方
- }
- if(TI)// 發送數據(1字節)完畢
- {
- TI = 0;// 將 發送中斷標志位 清零(讓串口可以繼續發送數據)
- }
- }
- void main(void)
- {
- init_uart();// 初始化串口
-
- while(1)// 主循環不做任何動作。(死循環)
- {}
- }
復制代碼
所有資料51hei提供下載:
串口通信仿真實驗.rar
(65.53 KB, 下載次數: 42)
2020-6-10 15:30 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
|