基于51 单片机的串口收发数据

在进行串口的收发数据过程中一定要注意波特率的问题。

大多数51单片机用的都是11m晶振而只有少部分用的是奇葩的12m(楼主的就是),在12m晶振进行串口通信时切忌要将波特率设置为4800以下,应为12m晶振的波特率在9600以上误差很大容易丢失数据,动手能力强的可以折腾一下用定时器输出9600波特率。

至于,串口中断以及波特率的设置可以参考网上例子忒多。

在用串口助手进行串口收发数据时都会触发串口中断并且在发送数据时只能够一位一位的发送,也就是SBUF=10是不行的智能一位一位发送也就是每次只能发送(0-9或者一个字符)并且串口调试助手接收到的数据是asii码要进行下转换,发送也要进行一下转换。这只是针对串口调试助手

话不多说直接上代码:

 

由于代码不方便公布所以只能上图片需要的可以私聊博主

 

 转载请标明原贴出处:https://blog.csdn.net/zj490044512

  • 17
    点赞
  • 135
    收藏
    觉得还不错? 一键收藏
  • 35
    评论
51单片机串口接收数据程序需要进行以下步骤: 1. 初始化串口,包括设置波特率、数据位、停止位等参数。 2. 开启串口接收中断,以便在接收到数据时能够及时处理。 3. 在中断服务函数中,读取接收缓冲区中的数据,并进行相应的处理。 4. 在主函数中,可以通过查询接收缓冲区是否有数据来判断是否接收到了数据。 下面是一个简单的51单片机串口接收数据程序的示例: ``` #include <reg52.h> // 定义串口参数 #define BAUDRATE 9600 #define DATA_BITS 8 #define STOP_BITS 1 // 定义接收缓冲区 #define BUFFER_SIZE 32 unsigned char buffer[BUFFER_SIZE]; unsigned char buffer_head = 0; unsigned char buffer_tail = 0; // 串口中断服务函数 void serial_isr() interrupt 4 { if (RI) { // 接收中断 RI = 0; buffer[buffer_tail] = SBUF; buffer_tail = (buffer_tail + 1) % BUFFER_SIZE; } } // 初始化串口 void init_serial() { TMOD |= 0x20; // 设置定时器1为模式2 TH1 = 256 - FOSC / 12 / BAUDRATE; // 计算波特率 TL1 = TH1; PCON &= 0x7F; // 波特率不加倍 SCON = 0x50; // 设置串口为模式1 ES = 1; // 开启串口中断 EA = 1; // 开启总中断 } // 查询接收缓冲区是否有数据 unsigned char serial_available() { return buffer_head != buffer_tail; } // 读取接收缓冲区中的数据 unsigned char serial_read() { unsigned char data = buffer[buffer_head]; buffer_head = (buffer_head + 1) % BUFFER_SIZE; return data; } void main() { init_serial(); while (1) { if (serial_available()) { unsigned char data = serial_read(); // 处理接收到的数据 } } } ```
评论 35
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值