单片机串口收发数据不可靠--用做指令会执行错误动作

单片机串口通信里最常见、最头疼的问题之一:发送端发出去的数据 ≠ 接收端收到的数据,一旦用来当指令,就会执行错误动作。


1. 为何不一样

串口(UART)本身是不可靠通信,没有纠错、没有重发。出现错误的常见原因:

  1. **电平干扰:**电机、继电器、电源噪声、线太长,都会把 0 变成 1、1 变成 0。

  2. **波特率不匹配 / 时钟偏差:**两个单片机晶振精度不一样,时间久了就错位,直接乱码。

  3. **起始位、停止位出错;**一个位错,整帧数据就废了。

  4. **缓冲区溢出:**发送太快、接收来不及处理,数据直接丢失或错位。

结果就是:你发 0x01(开灯),收到可能是 0x110x00 甚至乱码,单片机就会执行错误指令


2. 实际工程如何避免

不直接裸传指令,必须加校验和保护

常用方案(从简单到实用):

① 简单校验:奇偶校验

单片机硬件自带,能检出单 bit 错误,但不能纠错,错了就丢帧。

② 和校验 / 异或校验(常用)

格式类似:帧头 + 指令 + 数据长度 + 数据 + 校验和 + 帧尾

接收端重新算一遍校验和,对不上就直接丢弃,不执行。

③ 更稳一点:CRC16/CRC32

工业常用,抗干扰强,几乎不会误判。

④ 应答机制(ACK)

  • 发送 → 等待应答
  • 收不到正确应答 → 重发
  • 多次失败 → 报错

这样就能保证:要么收到正确指令,要么不收,绝不乱执行。


3. 最关键的原则

单片机绝对不能收到什么就执行什么!

正确逻辑应该是:

  1. 接收一帧完整数据
  2. 校验通过
  3. 指令在合法列表里
  4. 再执行

否则:

  • 电机乱转
  • 继电器乱吸合
  • 加热失控
  • 甚至设备损坏、危险

4. 总结

  • 裸奔串口确实会传错,指令会乱。
  • 裸奔串口(不加校验)只能用在不危险、不重要的场合。
  • 工业 / 控制场景必须:帧结构 + 校验 + 合法指令判断
相关推荐
fengfuyao98514 分钟前
GRBL 1.1 移植到 STM32 (HAL库)
stm32·单片机·嵌入式硬件
biyezuopinvip14 分钟前
基于STC89C51单片机的多波形信号发生器设计与Proteus仿真
单片机·proteus·课程设计·proteus仿真·基于stc89c51单片机的·多波形·信号发生器设计
无人装备硬件开发爱好者16 分钟前
STM32G474 驱动 1.54 寸三色电子墨水屏实现贪吃蛇游戏完整指南
stm32·嵌入式硬件·游戏
项目題供诗39 分钟前
STM32-定时器定时中断&定时器外部时钟(十一)
stm32·单片机·嵌入式硬件
披着假发的程序唐1 小时前
STM32 H743 MPU的配置使用方法
linux·c语言·c++·驱动开发·stm32·单片机·mcu
张健11564096481 小时前
MSP主堆栈指针
单片机
qxl_7999153 小时前
Windows 显卡掉线无报警|模型推理全套防呆方案(实操完整版)
windows·stm32·单片机·推理显卡掉线误报警防呆
hhb_6183 小时前
Armbian 的 root 密码“总被修改”
stm32·单片机·嵌入式硬件
项目題供诗10 小时前
STM32-TIM定时中断(十)
stm32·单片机·嵌入式硬件
普中科技10 小时前
【普中 51-Ai8051 开发攻略】-- 第 24 章 RTC 时钟实验
单片机·嵌入式硬件·rtc·实时时钟·普中科技·ai8051u·aicube