嵌入式软件开发之模块化程序设计(三)

模块化程序设计通过将大程序分解为独立、功能单一的模块,提高开发效率和代码稳定性。设计原则包括模块独立、适当规模和避免全局变量。每个模块通常由.C和.H文件组成,.H文件声明接口,.C文件实现功能。例如,OLED驱动模块可能包含SPI/IIC通信、配置和字体数据等子模块。

前言:

模块化程序设计是指在进行程序设计时将一个大程序按照功能划分为若干小程序模块,每个小程序模块完成一个确定的功能,并在这些模块之间建立必要的联系,通过模块的互相协作完成整个功能的程序设计方法。

模块化程序优点

  1. 提高开发速率:在新项目中可以直接移植其他项目中的模块程序,甚至无需修改直接使用,提高了代码的重用性
  2. 保证系统稳定性:该模块程序已通过之前的项目经过反复验证,稳定性高,在新项目中移植比重写更稳定
  3. 利于团队开发:可独立设计开发、调试和测试,利于团队分工合作
  4. 控制了程序设计的复杂性:各模块相对独立、功能单一,结构清晰、接口简单
  5. 易于维护和功能扩充:一旦出现问题,能迅速定位问题在哪个模块
  6. 提高了程序的可读性:即使没有相关设计文档,也能大致了解功能
  7. 程序的结构一目了然:可以看出程序中使用了哪些驱动、有哪些外设模块、大概有哪些功能等
  8. …等其他优点

设计思路

模块化程序设计的基本思想是自顶向下、逐步分解、分而治之,即将一个较大的程序按照功能分割成一些小模块,各模块相对独立、功能单一、结构清晰、接口简单。
例如,做一个手持遥控设备,在程序分层的基础上划分各个模块、如下图,硬件抽象层中就有通用 IO、ADC、定时器、CAN 等驱动 ,功能模块中有按键模块、储存模块和指示灯模块,应用层有人机交互功能,程序的结构一目了然

 

设计原则

模块化设计应该遵循以下几个主要原则:

  1. 模块独立 

模块的独立性原则表现在模块完成独立的功能,与其他模块的联系应该尽可能得简单,各个模块具有相对的独立性。

  1. 模块的规模要适当 

模块的规模不能太大,也不能太小。如果模块的功能太强,可读性就会较差,若模块的功能太弱,就会有很多的接口。开发者需要通过较多的程序设计来进行经验的积累。

  1. 分解模块时要注意层次 

在进行多层次任务分解时,要注意对问题进行抽象化。在分解初期,可以只考虑大的模块,在中期,再逐步进行细化,分解成较小的模块进行设计。

  1. 不对外开放全局变量 

模块内部使用的全局变量,需要外部修改或者获取时,需要通过封装成 API 函数对外提供,同时可以在函数内有相关限制,防止外部直接操作模块内部的全局变量引发模块运行异常,因此模块内部的全局变量可定义为静态全局变量。

如何理解?

模块即是一个.c 文件和一个.h 文件的结合,头文件(.h)中是对于该模块接口的声明

  1. 该模块的.c文件实现具体功能,而.h文件则为该功能模块的接口函数等
  2. 一个大模块中也会存在多个小模块,即模块中存在多个.c和.h文件,每个.c和.h作用各不相同

如:oled 驱动模块可细分 oledio.c/ oledio.h、oled.c/oled.h、oledconf.c/oledconf.h和 fontxx.h 等多个文件(注意层次,第一次划分模块时可以只有 oled.c/oled.h 实现所有功能),细分文件可参考 oled 驱动

oled.c 和 oled.h

实现具体功能,对外提供的 API 接口函数

oledio.c 和 oledio.h

硬件接口功能,实现 SPI 或 IIC 通信函数;移植需要修改

oledconf.c 和 oledconf.h

字体配置、图形配置和功能配置等

fontxxx.h 和 bmp.h

用来存放字体和图形BMP的点阵数据

转自:嵌入式软件开发之模块化程序设计(三)_嵌入式编程 模块化_大橙子疯的博客-CSDN博客


下篇:嵌入式软件开发之模块化程序设计(三)

内容概要:本文档围绕企业级STM32单片机(以STM32F103C8T6为例)的嵌入式软件设计,提供了一套完整的工程实践方案。文档从工程设计规范入手,提出分层架构(驱动层、工具层、应用层)、规范命名、容错设计、可扩展性与可移植性等核心要求,并给出了标准化的工程目录结构。通过详细的代码示例,展示了LED驱动、按键消抖、日志系统、看门狗等关键模块的实现方法,强调模块化封装与统一配置管理(config.h)。整体软件采用状态机驱动的应用逻辑,结合HAL库实现系统初始化、外设控制与异常处理,确保系统稳定可靠运行。同时配套提供了嵌入式软件设计概要文档,涵盖系统架构、模块设计、接口规范、异常容错、资源占用及测试维护等内容,形成完整的技术交付体系。; 适合人群:具备嵌入式C语言基础,熟悉STM32或正在从事基于STM32系列单片机开发的初级至中级工程师,以及需要构建标准化嵌入式项目的团队成员。; 使用场景及目标:①学习企业级嵌入式项目的工程组织结构与编码规范;②掌握STM32 HAL库下的外设驱动开发、状态机设计、日志系统与看门狗等实用技术;③应用于工业控制、智能设备等对稳定性、可维护性有较高要求的嵌入式系统开发中,提升项目质量与开发效率; 阅读建议:建议结合Keil等开发环境动手实践,逐步搭建并运行示例工程,重点理解分层架构的设计思想与config.h的集中配置机制,在调试过程中体会日志输出与看门狗的作用,并以此为基础进行功能扩展与性能优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值