【嵌入式项目应用】__单片机STM32有什么好的裸机程序架构思路推荐?

目录

前言

没设计好程序架构,根本做不稳定。

按照我的思维,我会这样去设计程序:

那这样的好处是什么? 

(* ̄︶ ̄)创作不易!期待你们的 点赞、收藏和评论喔。 


前言

在我刚出来的时候,都没有程序架构的概念,基本一个while死循环干到底。

模块之间也没有封装好,导致代码写好以后,扩展性和维护性太差,类似的功能代码,也很难移植到新项目去复用。

早期我也是这样写的,反正实现功能就行了,代码好不好,功能上又看不出区别。

不过,等你接触到复杂的项目时,这招就行不通了。

没设计好程序架构,根本做不稳定。

我意识到这个问题,是碰到两种需求的时候:

  1. 是做一个 基于STM32的网关项目 ,项目做完以后,客户老是要改功能,客户不懂技术,在客户眼里,觉得改一个LED闪烁效果很简单,但对于程序架构没设计好的工程师来说,就是一个噩梦,比如 每隔5秒快闪2次 这种恶心的需求,搞不好很多代码都要重新组织。我经常会被这种问题搞到头痛,特别是客户又催得急的时候,经常加班加到焦头烂耳,越急又越搞不出来。
  2. 我做过的很多项目,其实很多功能都有重复的,比如很多产品都有 LED按键掉电参数存储串口协议解析 等等。但是程序架构没写好,导致想移植代码,过来新项目复用时,不太好改,比如老项目才1个LED,新项目有6个LED,类似的还有按键等等。后面为了有更多的时间摸鱼,我开始思考,怎么把程序写得,改起功能来很方便,代码复用性又很强那种,当时还不知道这个叫 程序架构设计

程序架构,我觉得是一个系统的学问,贯穿着整个项目,而不是具体某些细节

就是各种功能模块,比如LED特效功能,按键检测功能,菜单功能,系统参数存储功能、语音功能、OTA升级功能等等。

这些功能模块的设计,我通常是采用硬件驱动代码和功能逻辑代码分离的方式,用大白话来说,就是一个功能模块,我可能会分2个.c文件来写,硬件驱动代码我以hal_xxx.c命名,功能逻辑代码我以mt_xxx.c命名。

硬件驱动代码主要是和单片机外设的配置代码,比如设置 GPIOTimer串口SPI 这些,然后提供硬件接口给 mt_xxx.c 调用。

拿无际项目特训营的项目6来举例,这个项目可以实现远程控制,因为加了WiFi和4G模块。

如果你接触过类似项目,单片机和云平台之间,其实还有个串口通讯协议的,类似于下图这种。

按照我的思维,我会这样去设计程序:

单片机外设驱动的配置、串口发送数据、接收数据代码,我都放在 hal_uart.c 里。

串口协议数据发送和解析的代码,我会放在 mt_protocol.c 文件里。 

这样就能实现硬件驱动代码和功能逻辑代码彻底分离。

那这样的好处是什么? 

  1. 万一要换单片机了,如果通讯协议不变的情况下,mt_protocol.c文件代码可以不用改,只要改hal_uart.c硬件驱动程序,就能对接起来。
  2. 如果通讯协议格式变了,单片机不变,那只需要改mt_protocol.c文件代码就可以了。
  3. 调试方便,比如mt_protocol.c的功能,可以在PC上搭建一个开发环境先调试好,再对接硬件驱动接口,对于复杂的功能,这招还是很有用的,毕竟keil仿真调试没那么方便灵活。

这种设计,就是一种架构思维,解决了代码扩展性和移植性的问题

如果每个功能模块都采用这种思维去设计,最终从整体看,你的程序架构就非常好了,就像组装汽车一样灵活了。

所以,要设计好程序架构,真的不是靠一个课程能搞定的,需要完整地做几个复杂的项目,并且有资深工程师的思路和代码,可以参考和借鉴,这样才能高效,系统地掌握

每个功能模块都设计好以后,最后还需要有一个协调者。

类似于人的大脑,去协调手、脚、眼睛、耳朵、嘴巴。

这个大脑,一般就是程序的"地基",类似于RTOS,就是"协调者"身份,负责调度协调整个项目的各个功能模块。

RTOS本质也是一种程序架构,但是我很少用,因为它的处境,其实很尴尬。

没那么复杂的项目,上RTOS并没有优势,反而为后期调试带来不必要的麻烦,如果对系统不熟悉,就像埋了一个定时炸弹,可能会跑一段时间后死机的现象。

复杂的项目,有些直接上Linux了,现在很多国产芯片,成本也能做得很低。

所以,现在rtos的应用,我觉得主要集中在中等复杂的项目,要求实时性很高,同时工程师,又不具备设计程序架构的能力时。

不过,至今为止,我基本是用自己设计的架构去替代RTOS,目前大多数产品都够用。

 


(* ̄︶ ̄)创作不易!期待你们的 点赞收藏评论喔。 

本文来源网络,免费分享知识,版权归原作者所有。如涉及作品版权问题,请联系我进行删除!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/152044.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux_在命令行中以树状结构显示目录_tree

1、安装tree命令 使用tree命令,可以在命令行中以树状结构显示目录,当你想知道一个路径下文件的结构时十分方便,还有别的选项功能,下面会介绍其中的一些,完整的介绍Linux命令 - tree—LZL在线工具。 sudo apt updates…

python对数据的处理合集——字典、列表...

1.两个列表的数据对比 ①list2包含了list1,求出list2多余的值 #codingutf-8list1[1,3,5] list2[1,3,5,7,9,11] list[] for i in list2:if i not in list1:list.append(i) print(list)②求出两个列共同的值 ③两个列表合并 #第一种: list1 [1, 2, 3] list2 [4, …

pyclipper和ClipperLib操作多边型

目录 1. 等距离缩放多边形 1.1 python 1.2 c 1. 等距离缩放多边形 1.1 python 环境配置pip install opencv-python opencv-contrib-python pip install pyclipper pip install numpy import cv2 import numpy as np import pyclipperdef equidistant_zoom_contour(contour…

YOLOv8/YOLOv7/YOLOv5/YOLOv4/Faster-rcnn系列算法改进【NO.77】引入百度最新提出RT-DETR模型中AIFI模块

前言 作为当前先进的深度学习目标检测算法YOLOv8,已经集合了大量的trick,但是还是有提高和改进的空间,针对具体应用场景下的检测难点,可以不同的改进方法。此后的系列文章,将重点对YOLOv8的如何改进进行详细的介绍&…

openbabel包的安装

今天在安装openbabel的时候,使用pip / 通过源码的方式进行安装openbabel,但是都并没有什么用,直接使用: conda install openbabel 就openbabel3.1.1成功了

Authorization为啥必须要以Bearer开头

最近在公司使用JWT,对请求头信息中的Authorization必须要以Bearer开头有一些疑问,查了一下文档,知道了: Authorization: Bearer your_access_tokenBearer代表Authorization头定义的schema ,除了Bearer,还有…

2760. 最长奇偶子数组 : 抽丝剥茧,图解双指针做法正确性

题目描述 这是 LeetCode 上的 「2698. 求一个整数的惩罚数」 ,难度为 「简单」。 Tag : 「双指针」、「滑动窗口」 给你一个下标从 开始的整数数组 nums 和一个整数 threshold。 请你从 nums 的子数组中找出以下标 l 开头、下标 r 结尾 ( ) 且满足以下条件的 最长子…

【汇编】mov和add指令、确定物理地址的方法、内存分段表示法

文章目录 前言一、学习汇编指令——用中学1.1 汇编指令分析汇编输出分析 二、确定物理地址的方法2.1 什么叫做物理地址2.2 8086中的物理地址2.3 8086CPU给出物理地址的方法2.4 “段地址16偏移地址物理地址”的本质含义 三、内存分段表示法3.1 用分段的方式管理内存3.2 同一段内…

基于SSM的实验室仪器设备管理系统设计与实现

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:采用JSP技术开发 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目&#x…

【数据结构高阶】二叉搜索树

接下来我们来开始使用C来详细讲解数据结构的一些高阶的知识点 本期讲解的是二叉搜索树,对于初阶二叉树有所遗忘的同学可以看到这里: 【精选】【数据结构初阶】链式二叉树的解析及一些基本操作 讲解二叉搜索树主要是为了后面的map和set做铺垫&#xff…

HTML易忽略的角落【目录】

目前已有文章 **** 篇 本专栏是汇集了一些HTML常常被遗忘的知识,这里算是温故而知新,往往这些零碎的知识点,在你开发中能起到炸惊效果。我们每个人都没有过目不忘,过久不忘的本事,就让这一点点知识慢慢渗透你的脑海。 …

【Spring】超详细讲解AOP(面向切面编程)

文章目录 1. 前言2. 什么是AOP3. AOP快速入门4. AOP的核心概念5. 切点表达式6. 切点函数7. 通知8. 总结 1. 前言 本文围绕AOP进行讲解,AOP可以做什么,涉及到了哪些注解,以及各个注解运行的时机,以及Around相较于其它注解有什么不同,并且如果要执行目标方法需要怎么做 2. 什么…

群晖7.2版本通过Container Manager安装xiaoya-alist

小雅Alist,可以说是Alist应用中挂载阿里云最完美的成功案例。 一、下载镜像 注册表中下载镜像 Container Manager应该是7.2版本才改名,就是以前的docker。 打开【Container Manager】-【注册表】-【搜索框】搜索 xiaoya 内容区域,搜出的…

新零售系统平台解决方案 线上线下小程序怎么做

新零售线上线下解决方案是将传统零售业务与互联网科技相结合,通过数字化、智能化手段提升零售业务效率和用户体验的解决方案,它既有提供消费者线下体验,强调“稳”,又有互联网线上的“快”。 线上线下小程序可以通过一体化的进销存…

ubuntu20.04安装cv2

查看ubuntu的版本 cat /etc/lsb-release DISTRIB_IDUbuntu DISTRIB_RELEASE20.04 DISTRIB_CODENAMEfocal DISTRIB_DESCRIPTION"Ubuntu 20.04.3 LTS"更改镜像源 cp /etc/apt/sources.list /etc/apt/sources.list.bak cat > /etc/apt/sources.listdeb http://mirr…

第二证券:注册制退市规则?

跟着我国本钱商场不断发展和完善,持续注重退市原则改造也成为了商场中的热点话题。而注册制退市规矩的施行,无疑是新的退市原则下的一大重要内容。 首要,咱们需求了解什么是注册制退市规矩。所谓注册制退市规矩,指的是在注册制下…

App加固中的代码混淆功能,让逆向工程师很头疼

App加固中的代码混淆功能,让逆向工程师很头疼 “我想离开浪浪山。” 在数次尝试破解某个App 时,某个逆向工程师无奈感慨道。 逆向工程师顾名思义就是把一个个完整的软件逆推,还原成一段段代码,方便破解。 比如给他们一个手机Ap…

windows 使用WinSW制作服务

背景:最近维护老项目,需要使用windows server 2012 r2部署项目。使用springboot开发项目,nginx部署前端,于是打算把jar包和nginx都制作成服务 下载winsw地址:https://github.com/winsw/winsw/releases 下载这两个文件…

内衣迷你洗衣机什么牌子好?选购内衣裤洗衣机的方法

洗衣机在我们的生活中可谓是非常常见的了,几乎每家每户都具备着一台。即便是有洗衣机,也有不少人不会将自己我贴身衣物直接扔在洗衣机里清洗,而是会自己手工手洗。这跟我们传统上的观念有很大的关系,认为把内衣、内裤等贴身衣物放…

【23真题】发错试卷?想多了,只是题型大改!

今天分享的是23年南昌大学811的信号与系统试题及解析。南昌大学23年题型大改,加入了很多电路题目!23考研的同学,甚至考场上以为发错试卷,考的电路原理。所以学有余力的同学,一定跟着我做各种院校的真题,见多…