掌握这招,串口通信高频收发32W数据,0丢包!

2024-06-14 20:36

本文主要是介绍掌握这招,串口通信高频收发32W数据,0丢包!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我做过挺多串口通讯类的产品,有用485通讯的pdu,有wifi/4G/蓝牙通讯类的网关...

做串口的应用,把串口外设调通只是第一步,串口只是数据传输的媒介,在此基础上,两个设备/器件要进行通信,传递更有意义的信息,还需要一个通讯协议。

如果没有协议设计经验,可以用标准协议,比如Modbus。

也可以自己设计通信协议,比如我们无际项目特训营的物联网串口通讯协议。

该协议负责网关和云平台/APP的数据交互。

串口通讯的难点和重点,不在于串口外设本身,而是基于串口的增值功能,比如协议设计和解析,其稳定性的考量。

早期做pdu的时候,用485通讯,Modbus协议,我是做从机,当时没什么经验,总是做不稳定,如果是碰上那种对成本要求很苛刻的产品,比如连一个电容钱都要省的,调起来极其恶心,想把公司电脑都砸了。

解析协议数据时,写程序也非常头疼,最常见的就是定义数组作为缓存,去接收数据,不过用这种方式程序写起来比较麻烦,全局变量满天飞。

如果一边接收,一边解析,然后再发送数据,难免会有多个程序同时访问和修改数组的情况,这样管理数据的插入和删除,就会大大增加了程序的复杂性。

如果没有足够的经验,很容易引起数据错乱,丢包,就是一帧协议数据,丢了其中1个或者几个字节。

所以,这篇文章,是解决如何用应对高频数据流的问题,这种方法,不仅仅能用于串口,也适用其它大数据流处理的场景。

这个时候,需要用到一种数据结构,叫队列

队列可以更好地保证数据的完整性和顺序,因为队列是先进先出(FIFO)的数据结构,而数组可能会因为覆盖或重新分配而导致数据顺序混乱。

其实队列,也没想象中这么玄乎,就是在数组/内存里面,写一些入列/出列的小算法,去管理这些数组/内存。

如果想学写队列这种数据结构,我知道的两个渠道。

第一,可以看我2018年录制的那套程序架构教程,里面有手把手教写队列代码的章节。

通过这些结构体,可以根据应用场景,定义不同大小的队列。

然后通过4个函数,去管理定义好的队列,比如清空、入列、出列、判断队列有效数据长度。

这个队列相对简单,缺点是只能入列单个字节的数据类型,不过大多数单片机项目也够用。

第二,RTOS也有队列代码,不过是用链表这种数据结构,更加复杂一点,优点是支持任意数据类型入列。

我一般是用自己写的那个,因为能100%掌控,使用也简单,而且经过了大批量产品验证,稳得一批。

下图是我们用无际单片机特训营项目3做的实验,单片机型号为STM32F103,以10ms的频率发送和接收串口数据,测试了32.5W个字节数据,0丢包。

这个代码,我并没有用DMA,如果用DMA,效率更高。

下面讲下我是怎么做的,其实贼简单。

DebugTxMsg是全局队列,大小为256个字节,这个可以根据单片机资源、实际应用的数据量大小、频率去调节。

当串口收到一个字节数据,我就直接丢进队列里。什么数组下标++,判断数组是否满之类的操作,其实是在队列入列函数里完成的,一次写好后,无限复用。

然后,有专门的函数,用来处理队列的数据,如果判断队列里有数据,就通过串口1再发送出去。

QueueDataOut是一个队列数据出列函数,函数内部实现了先进先出的算法,所以我们完全不用管什么数组下标,数组还有多少数据之类的,也是一次写好,无限复用,大大简化了程序。

hal_debugProc这个函数,是一直main函数里轮询执行的,所以只要队列有数据,就会被发送出去。

这个阶段,能够测试数据接收是否完整,稳定,测试通过以后,再去实现协议解析的代码。

写程序有点像下棋,走一步看百步,前期搭好程序架构,后期做细节功能会很高效稳定。


最近很多粉丝问我单片机怎么学,我根据自己从业十年经验,累积耗时一个月,精心整理一份「单

片机最佳学习路径+单片机入门到高级教程+工具包」全部无偿分享给铁粉!!!

除此以外,再含泪分享我压箱底的22个热门开源项目,包含源码+原理图+PCB+说明文档,让你迅速进阶成高手

教程资料包和详细的学习路径可以看我下面这篇文章的开头

《单片机入门到高级开挂学习路径(附教程+工具)》

《单片机入门到高级开挂学习路径(附教程+工具)》

《单片机入门到高级开挂学习路径(附教程+工具)》

这篇关于掌握这招,串口通信高频收发32W数据,0丢包!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1061440

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

pandas数据过滤

Pandas 数据过滤方法 Pandas 提供了多种方法来过滤数据,可以根据不同的条件进行筛选。以下是一些常见的 Pandas 数据过滤方法,结合实例进行讲解,希望能帮你快速理解。 1. 基于条件筛选行 可以使用布尔索引来根据条件过滤行。 import pandas as pd# 创建示例数据data = {'Name': ['Alice', 'Bob', 'Charlie', 'Dav

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识