当前位置: 首页 > article >正文

STM32实战:串口USART数据收发与中断处理(基于STM32F103C8T6标准库)*从零到一*

1. 串口通信基础与STM32硬件准备第一次接触STM32串口通信时我对着USART和UART这两个词发懵——后来发现它们就像孪生兄弟USART比UART多了同步时钟功能。我们常用的STM32F103C8T6开发板上有3个USART接口最常用的是USART1对应PA9(TX)和PA10(RX)引脚。记得有次调试时把TX和RX接反了数据死活传不过去排查半天才发现这个低级错误。硬件连接其实特别简单用USB转TTL模块连接开发板时记住交叉连接原则模块的TX接开发板RX模块的RX接开发板TX。供电方面我习惯用3.3V供电避免电平不匹配。有个实用小技巧在PA9和PA10引脚加上10K上拉电阻能显著提高通信稳定性特别是在长距离传输时。开发环境搭建也有讲究Keil MDK要安装STM32F1的Device Family Pack建议使用ST-Link V2下载调试器串口助手推荐SecureCRT或者Putty安装CH340/CP2102等USB转串口驱动2. 标准库串口初始化实战初始化USART就像给快递站配置送货规则得先告诉系统几个关键参数。下面这段代码我调过不下20次现在闭着眼睛都能写出来void USART1_Init(uint32_t baudrate) { // 1. 开启时钟不开启时钟啥都干不了 RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA, ENABLE); // 2. GPIO配置 GPIO_InitTypeDef GPIO_InitStruct; GPIO_InitStruct.GPIO_Pin GPIO_Pin_9; // TX GPIO_InitStruct.GPIO_Mode GPIO_Mode_AF_PP; GPIO_InitStruct.GPIO_Speed GPIO_Speed_50MHz; GPIO_Init(GPIOA, GPIO_InitStruct); GPIO_InitStruct.GPIO_Pin GPIO_Pin_10; // RX GPIO_InitStruct.GPIO_Mode GPIO_Mode_IN_FLOATING; GPIO_Init(GPIOA, GPIO_InitStruct); // 3. USART参数配置 USART_InitTypeDef USART_InitStruct; USART_InitStruct.USART_BaudRate baudrate; USART_InitStruct.USART_WordLength USART_WordLength_8b; USART_InitStruct.USART_StopBits USART_StopBits_1; USART_InitStruct.USART_Parity USART_Parity_No; USART_InitStruct.USART_Mode USART_Mode_Tx | USART_Mode_Rx; USART_InitStruct.USART_HardwareFlowControl USART_HardwareFlowControl_None; USART_Init(USART1, USART_InitStruct); // 4. 使能串口 USART_Cmd(USART1, ENABLE); }波特率设置有个坑当使用72MHz系统时钟时9600波特率会有0.16%误差而115200波特率误差高达2.12%。实际测试发现当误差超过1.5%时就会出现乱码。解决方法要么改用误差小的波特率如57600要么调整系统时钟频率。3. 数据发送的四种实用方法3.1 基础字节发送最基础的发送函数就像快递员送单个包裹void USART_SendByte(USART_TypeDef* USARTx, uint8_t data) { USART_SendData(USARTx, data); while(USART_GetFlagStatus(USARTx, USART_FLAG_TXE) RESET); }这里有个关键点必须等待TXE发送寄存器空标志置位否则会丢失数据。我曾在高速发送时没加这个等待结果数据像漏水的管子一样丢失了大半。3.2 高效数组发送发送数组就像批量发货void USART_SendArray(USART_TypeDef* USARTx, uint8_t *arr, uint16_t len) { while(len--) { USART_SendByte(USARTx, *arr); // 添加小延时可提高稳定性 for(volatile int i0; i100; i); } }实测发现在115200波特率下不加延时会丢失约3%的数据包。这个小技巧帮我解决了产品量产时的通信故障。3.3 字符串发送优化字符串发送最容易遇到乱码问题void USART_SendStr(USART_TypeDef* USARTx, char *str) { while(*str) { // 处理中文乱码 if((uint8_t)*str 0x7F) { USART_SendByte(USARTx, *str); USART_SendByte(USARTx, *str); } else { USART_SendByte(USARTx, *str); } } }配合Keil的--no-multibyte-chars编译选项能彻底解决中文乱码问题。这个方案是我们团队经过两个月调试才找到的终极解决方案。3.4 数字格式化输出数字转字符串是个常见需求void USART_SendNum(USART_TypeDef* USARTx, int32_t num) { char buf[12]; int i 0; if(num 0) { USART_SendByte(USARTx, -); num -num; } do { buf[i] num % 10 0; num / 10; } while(num); while(i--) { USART_SendByte(USARTx, buf[i]); } }这个算法比用sprintf节省了2KB的Flash空间在资源紧张的C8T6上特别实用。4. 中断接收与数据处理4.1 查询方式接收查询方式就像定期检查邮箱uint8_t USART_ReceiveByte(USART_TypeDef* USARTx) { while(USART_GetFlagStatus(USARTx, USART_FLAG_RXNE) RESET); return USART_ReceiveData(USARTx); }这种方式简单但效率低实测在9600波特率下会占用80%的CPU资源。适合用在简单场景但产品级项目建议用中断方式。4.2 中断接收实战中断方式就像安装了个门铃// 在初始化代码中添加中断配置 USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); NVIC_EnableIRQ(USART1_IRQn); // 中断服务函数 volatile uint8_t rx_buffer[64]; volatile uint8_t rx_index 0; void USART1_IRQHandler(void) { if(USART_GetITStatus(USART1, USART_IT_RXNE)) { uint8_t data USART_ReceiveData(USART1); if(rx_index sizeof(rx_buffer)) { rx_buffer[rx_index] data; // 遇到换行符认为接收完成 if(data \n) { process_received_data(); rx_index 0; } } else { rx_index 0; // 防止缓冲区溢出 } USART_ClearITPendingBit(USART1, USART_IT_RXNE); } }这个方案我们用在智能家居产品中稳定处理了每秒200条指令。关键点有三个使用volatile防止编译器优化、及时清除中断标志、做好缓冲区溢出保护。4.3 数据协议解析实际项目中最常用的是MODBUS协议格式typedef struct { uint8_t addr; uint8_t func; uint16_t reg; uint16_t value; uint16_t crc; } MODBUS_Frame; void parse_modbus(uint8_t *data) { MODBUS_Frame *frame (MODBUS_Frame *)data; // CRC校验 if(verify_crc(frame)) { switch(frame-func) { case 0x03: // 读保持寄存器 handle_read_reg(frame-reg); break; case 0x06: // 写单个寄存器 handle_write_reg(frame-reg, frame-value); break; } } }加上CRC校验后通信误码率从10^-4降到了10^-7。这个经验来自一次工厂现场调试电气干扰导致大量数据错误加入CRC后问题迎刃而解。5. 常见问题与性能优化5.1 波特率误差问题STM32F103的USART时钟来自APB2总线72MHz计算波特率时会产生误差。通过实测发现目标波特率实际波特率误差率960095980.02%1152001125002.34%2304002250002.34%解决方案有两种改用误差小的波特率如57600误差仅0.16%调整系统时钟使APB2频率能被波特率整除5.2 抗干扰措施在工业环境中总结出这些经验在TX/RX线上串联100Ω电阻并联30pF电容滤波使用双绞线传输添加TVS二极管防静电软件上增加重传机制5.3 内存优化技巧对于只有20KB RAM的C8T6这些技巧很实用使用DMA传输节省CPU资源环形缓冲区替代线性缓冲区用位域压缩协议字段关键变量加上__attribute__((aligned(4)))有个项目原本需要32KB内存通过这些优化最终只用了14KB就实现了全部功能。6. 进阶应用DMAUSART高效传输当需要传输大量数据时DMA就像雇了个专职快递员void USART1_DMA_Init(void) { // 开启DMA时钟 RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE); DMA_InitTypeDef DMA_InitStruct; DMA_InitStruct.DMA_PeripheralBaseAddr (uint32_t)USART1-DR; DMA_InitStruct.DMA_MemoryBaseAddr (uint32_t)tx_buffer; DMA_InitStruct.DMA_DIR DMA_DIR_PeripheralDST; DMA_InitStruct.DMA_BufferSize 0; DMA_InitStruct.DMA_PeripheralInc DMA_PeripheralInc_Disable; DMA_InitStruct.DMA_MemoryInc DMA_MemoryInc_Enable; DMA_InitStruct.DMA_PeripheralDataSize DMA_PeripheralDataSize_Byte; DMA_InitStruct.DMA_MemoryDataSize DMA_MemoryDataSize_Byte; DMA_InitStruct.DMA_Mode DMA_Mode_Normal; DMA_InitStruct.DMA_Priority DMA_Priority_High; DMA_InitStruct.DMA_M2M DMA_M2M_Disable; DMA_Init(DMA1_Channel4, DMA_InitStruct); USART_DMACmd(USART1, USART_DMAReq_Tx, ENABLE); } void USART1_DMA_Send(uint8_t *data, uint16_t len) { while(DMA_GetCmdStatus(DMA1_Channel4) ENABLE); // 等待上次传输完成 DMA_Cmd(DMA1_Channel4, DISABLE); DMA_SetCurrDataCounter(DMA1_Channel4, len); DMA1_Channel4-CMAR (uint32_t)data; DMA_Cmd(DMA1_Channel4, ENABLE); }实测DMA传输比中断方式快3倍CPU占用率从70%降到5%。这个方案在我们的一款数据采集设备上实现了每秒1MB的稳定传输。

相关文章:

STM32实战:串口USART数据收发与中断处理(基于STM32F103C8T6标准库)*从零到一*

1. 串口通信基础与STM32硬件准备 第一次接触STM32串口通信时,我对着USART和UART这两个词发懵——后来发现它们就像孪生兄弟,USART比UART多了同步时钟功能。我们常用的STM32F103C8T6开发板上有3个USART接口,最常用的是USART1,对应P…...

Ansible之Playbook(五):高级用法

Playbook高级用法一、本地执行(Local Action)应用场景当控制节点(非目标主机)需要执行特定操作时使用,如生成报告、处理临时文件等。OpenEuler实现方式- name: 在控制节点生成主机清单报告hosts: alltasks:- name: 收集…...

用于街头拍摄的摄像头

1 充电宝2 太阳能板我觉得用充电宝,物联网低功耗摄像头就可以了,因为录制的视频是等到拿回去以后再分析的,不用联网,联网是为了确保摄像头的安全,不被别人拿走。但是这个安装的过程:1 如果晚上12点去安装&a…...

未来5年最“钱“景岗位揭晓:AI产品经理,普通人如何从0到1逆袭?(内含3步进阶法+学习资源)

文章指出AI产品经理是未来5年最具潜力的岗位,并分析了想抓住AI机会的人常遇到的3种状态:观望者、探索者和跑偏者。文章将AI产品经理分为工具型、应用型和专业型,建议普通人以成为应用型AI产品经理为目标。文章提出了从入门到上手的3步学习法&…...

c++ string字符串详解

一.string背景以及需要了解的知识点 1.1STL string是STL的一部分,但是STL创建的比string晚一些,后面才把string加入到STL里。STL(standard template library)是c的重要组成部分,可以简单理解为一个囊括了数据结构里面我们学的结构与算法的集…...

AutoLisp实战:从零到一构建你的第一个绘图工具

1. 为什么选择AutoLisp来自动化绘图 如果你经常使用AutoCAD进行绘图工作,一定会遇到大量重复性的操作。比如每次都要手动选择两点画线,然后再单独添加标注。这种机械劳动不仅效率低下,还容易出错。AutoLisp就是AutoCAD内置的解决方案&#xf…...

Java-Study

基础环境搭建 下载jdk JDK 26 Documentation - Home JDK(Java Development Kit,Java 开发工具包) 是开发、编译、运行 Java 程序的核心基础环境,相当于你写 Java 代码的「工具箱 + 编译器 + 运行环境」三合一。 JDK 里到底有什么?(核心组成) JDK 不是一个单独的程序…...

如何科学构建TVA项目的成功标尺:从KPI设定到价值闭环

「本文已用流量券推广,欢迎收藏 关注」技术背景介绍:AI智能体视觉检测系统(TVA,全称为“Transformer-based Vision Agent”),即基于Transformer架构以及“因式智能体”创新理论的高精度视觉智能体&#xf…...

中国首部纯 AI 制作院线电影《第一大道》高清资源下载与观影指南

一、电影基本信息 《第一大道》是2026年推出的中国首部纯AI制作院线级史诗电影,由王铁编剧执导,全程采用字节跳动Seedance 2.0模型生成,片长150分钟,2K电影级画质(20481080),融合历史、权谋、科…...

Java工程师视角:j-langchain 快速上手 Agent

引言:为什么 Java 工程师也需要 Agent? 过去两年,几乎所有 AI Agent 教程都默认使用 Python。 你看到的往往是: LangChainLangGraphAutoGenCrewAI 但现实情况是,大多数企业后端系统并不是 Python,而是 Java…...

豆包 Rocky Linux 10.1 环境下 100 道 grep 命令高频面试题 + 详细答案

Rocky Linux 10.1 环境下 100 道 grep 命令高频面试题 + 详细答案 全部基于 GNU grep,可直接在 Rocky Linux 10.1 / RHEL 10 / CentOS Stream 上运行验证,覆盖基础、正则、递归、过滤、运维场景、性能与坑点。 一、基础用法(1–10) 1. grep 基本语法 答案 grep [选项] …...

Photon光影包深度技术解析:从物理渲染到游戏体验的全面优化方案

Photon光影包深度技术解析:从物理渲染到游戏体验的全面优化方案 【免费下载链接】photon A gameplay-focused shader pack for Minecraft 项目地址: https://gitcode.com/gh_mirrors/photon3/photon Photon是一个专注于游戏体验的Minecraft光影包&#xff0c…...

LVGL实战:5分钟用ESP32驱动ST7789屏幕打造智能家居控制面板(附完整代码)

ESP32LVGLST7789智能家居控制面板实战指南 1. 硬件准备与环境搭建 在开始之前,我们需要准备好所有必要的硬件组件。ESP32开发板因其强大的处理能力和丰富的接口资源,成为物联网项目的首选。ST7789则是一款性价比极高的TFT LCD驱动芯片,支持24…...

Maple_公式推导进阶:subs与isolate的高效应用技巧

1. Maple公式推导的核心优势 第一次接触Maple时,我被它纸面般的公式显示效果惊艳到了。这就像用钢笔在草稿纸上演算,但永远不用担心写错——因为随时可以按CtrlZ重来。在完成流体力学方程的推导项目后,我总结了Maple最打动工程师的四个特点&a…...

手把手教你用GD32的ADC+DMA实现多通道数据采集(含二分查找法优化技巧)

GD32多通道ADC数据采集实战:从DMA配置到二分查找优化 在嵌入式开发中,模拟信号采集是连接物理世界与数字系统的关键桥梁。GD32系列MCU凭借其高性能ADC模块和灵活的DMA控制器,为多通道数据采集提供了可靠解决方案。本文将带您从基础配置到高级…...

高项论文「范围管理」超详细写作攻略:从框架到字句,手把手教你写出高分答卷

前言:阅卷老师到底在看什么? 很多人认为论文是“玄学”,其实不然。范围管理论文的评分标准非常清晰,阅卷老师在几分钟内重点抓取以下5个关键得分维度:得分维度占比具体含义你的对策结构完整性20%6个子过程是否全部覆盖…...

如何用AI修复受损音频:VoiceFixer完整指南

如何用AI修复受损音频:VoiceFixer完整指南 【免费下载链接】voicefixer General Speech Restoration 项目地址: https://gitcode.com/gh_mirrors/vo/voicefixer 还在为嘈杂的录音、失真的语音或老旧音频而烦恼吗?VoiceFixer是你的AI音频修复专家&…...

如何快速通过手机号找回QQ账号:Python工具终极指南

如何快速通过手机号找回QQ账号:Python工具终极指南 【免费下载链接】phone2qq 项目地址: https://gitcode.com/gh_mirrors/ph/phone2qq 你是否曾经因为忘记QQ号而无法登录工作群聊,或者因为更换手机导致重要账号无法找回?现在&#x…...

Spring Boot 4 Spring Data AOT:从反射深渊到编译时确定性

我们是由枫哥组建的IT技术团队,成立于2017年,致力于帮助IT从业者提供实力,成功入职理想企业,我们提供一对一学习辅导,由知名大厂导师指导,分享Java技术、参与项目实战等服务,并为学员定制职业规…...

当医生意见不一时,AI怎么办?聊聊CVPR 2025 AmbiSSL如何解决医学图像分割的‘标注模糊’难题

当医生意见不一时,AI如何破局?解读CVPR 2025 AmbiSSL在医学图像分割中的创新实践 在放射科读片室里,三位资深医师正对同一张肺部CT片展开讨论。一位认为结节边缘需要扩大2mm勾画以确保安全切除,另一位坚持精确贴合可见边界&#x…...

AI声学A-59P模组:智能降噪,清晰通话

随着物联网与智能交互技术普及,语音已成为人机交互的主流入口。在楼宇对讲、车载通讯、远程会议、安防拾音等实际场景中,设备常面临稳态噪声(空调 / 风扇)、冲击噪声(敲击 / 碰撞)、风噪、交通噪声及强耦合…...

计算机网络 --- 动态路由

静态路由:由网络管理员手工配置的路由信息动态路由:所有路由器运行相同的路由协议,彼此之间沟通交流最终计算出到达未知网段的路由信息静态路由:优点:1.静态路由选路更加合理2.不需要额外消耗资源3.更加安全缺点&#…...

基于“灵珠AI平台”从0到1搭建一个博物馆数字人导游智能体教程

一、前言 有没有小伙伴去过博物馆?是不是经常遇到这种情况:租一个讲解器,走到哪听到哪,但它只管自己讲,根本不关心你想听什么。你对某件青铜器特别好奇,想多问两句?不好意思,讲解器不…...

寄存器与操作寄存器(小白级教学)

前言到目前为止,计算机依然只能读入二进制,此时肯定会有读者好奇了,那我们电脑中各种各样的图案,声音还有颜色都是如何来的呢,因为电脑本身就是硬件,硬件内部中,1就是代表高电压,0就…...

MyBatisPlus之核心功能+扩展功能

1.核心功能之Lamba更新普通写法:基于lamba写法:1.在controller层中编写接口,调用一个自己写的方法2.在IUserService接口,在UserServiceImpl实现该方法3.在UserServiceImpl编写代码,使用Lamba编写与lambdaQuery方法类似…...

用python实现一个简单的聊天功能

学完了python基础,写一个脚本,调用通义千问大模型API实现一个简单的聊天功能。 一、准备工作 1、执行以下命令,安装请求库 pip install requests 2、去通义千问开放平台申请API Key 注册阿里云账号并完成实名认证:https://das…...

Flutter 开源鸿蒙动效实战:全场景动效集成精简指南

🎉 Flutter 开源鸿蒙动效实战:全场景动效集成精简指南(鸿蒙兼容 可直接运行) 欢迎加入开源鸿蒙跨平台社区→https://openharmonycrosplatform.csdn.net 哈喽宝子们!我是刚学跨平台开发的大一新生😆 这次给我的鸿蒙 …...

别再裸奔了!给若依前后端分离项目加上AES接口加密(Vue3 + Spring Boot保姆级配置)

若依框架前后端分离项目AES接口加密实战指南 在当今数据安全日益重要的环境下,企业级应用开发中接口传输的安全性已成为不可忽视的一环。许多开发者在使用若依这类优秀框架时,往往只关注功能实现而忽略了数据传输过程中的安全隐患。本文将带您从零开始&a…...

D2: AI 工具的 ROI 评估框架(附 Excel 模板)

文章目录 D2: AI 工具的 ROI 评估框架(附 Excel 模板) 🎯 为什么这个话题重要? 现实痛点 真实案例 本章价值 核心内容 一、ROI 评估的核心公式 直接收益(可量化) 间接收益(需估算) 显性成本(必须计算) 隐性成本(最容易被低估) 风险成本(必须量化) 二、五维评估模…...

任务管理器怎么打开?【图文讲解】电脑卡死怎么关程序?任务管理器快捷键?电脑结束任务快捷键?6 种超简单方法,电脑卡死一键救急!

(1)问题背景 谁没碰到过电脑当场 “摆烂” 的崩溃时刻?软件卡死不动、页面关不掉、鼠标点啥都没反应,整个电脑卡成 PPT,急得人直跺脚! 这时候能救电脑于水火的,只有任务管理器。它就像电脑的急…...