单片机项目中太多全局变量有什么弊端?

news2024/11/20 4:20:42

最近有读者遇到了这样的问题:

入职接到前同事丢下的“烂摊子”,项目中很多全局变量······

问我:全局变量太多有哪些弊端?该如何规避,以及如何管理全局变量等。

全局变量太多有哪些弊端?

真正做过项目的同学应该都能明白,项目中全局变量太多,会存在很多问题。

这里给大家罗列一些太多全局变量可能存在的弊端:

1、代码可读性差

漫天全局变量,特别是各个源文件都有全部变量的情况下,代码可读性相信你都能明白有多差。

如果再加上命名不规范、随处定义,代码可读性更是不能言语。

2、代码维护难度大

随着全局变量的增多,不同模块的变量名可能会产生冲突或混淆,导致代码难以理解和维护。同时,全局变量使得代码中的依赖关系变得复杂,难以追踪和理解。这增加了新开发人员的学习成本,也增加了修改和调试的难度。

3、可移植性差

全局变量通常与特定的硬件或系统配置紧密相关,各个文件都在调用全局变量,这使得代码的可移植性很差。

再次就是,随着项目的增长和功能的增加,全局变量的管理和维护变得更加困难,这限制了项目的可扩展性。

5463a1db7341f40ce2b9c44ae39ff309.jpeg

4、内存管理问题

全局变量太多会导致内存泄漏,以及碎片等诸多问题。

内存泄漏:如果没有适当地管理全局变量的生命周期,可能会导致内存泄漏,特别是在资源受限的单片机环境中。

内存碎片:频繁地分配和释放全局变量相关的内存可能导致内存碎片,降低内存利用效率。

5、潜在bug

随着全局变量的增多,出现bug的概率越大,多个函数或模块可能同时访问和修改全局变量,如果没有适当的同步机制,会导致数据不一致和难以预测的行为。

一个函数对全局变量的修改可能会影响到其他不相关的函数,这种隐式的副作用使得错误难以定位和修复。

6、不利于模块化设计

如果全局变量在各个模块中穿插使用,不仅破坏了模块的独立性,还使得模块之间的耦合度增加,降低了代码的可重用性和可维护性。

通常来说,模块化设计的代码,不会存在全局变量,或者很少有全局变量。

7、增加调试难度

在单元测试测试,或项目全局测试时,全局变量的状态管理变得复杂。测试人员需要确保在每次测试之前全局变量处于正确的状态。如果全局变量的修改可能发生在代码的多个位置,这使得调试时难以确定问题的根源。

8、更多弊端

以上是常见的弊端,还有哪些弊端,大家可以留言讨论。

全局变量太多如何规避?

全局变量太多有诸多弊端,那么如何规避呢?

1、使用静态局部变量

在某些情况下,可以使用静态局部变量来替代全局变量,这样就避免了其他地方修改全局变量。

2、使用指针和引用

在函数内部,可以通过指针或引用来访问和修改外部变量的值,而无需直接声明为全局变量。

3、使用函数参数

在函数内部,尽量使用局部变量来存储临时数据,而不是依赖全局变量。

通过函数参数来传递需要的数据,并通过返回值来获取结果,而不是直接访问或修改全局变量。

b2bb6ba8936e9f28be101dbc5fdc44d0.jpeg

4、封装和模块化

将相关的变量和函数封装在结构体或类中,通过接口进行访问和修改。

将代码划分为多个模块,每个模块负责特定的功能,并通过接口与其他模块交互。

5、定期优化代码

一个好的项目,肯定需要是定期维护和优化。比如优化数据结构和算法,减少不必要的全局变量,甚至定期重构部分模块代码。

6、增加审查团队

一般大公司会有专门的代码审查相关的部门,进行定期的代码审查,强调全局变量使用的危害,并鼓励团队成员寻找替代方案。

通过团队协作和讨论,共同寻找最佳实践,也能减少全局变量的使用。

------------ END ------------

59f3b5a98bac9140b96eaabc9d964215.gif

●专栏《嵌入式工具

●专栏《嵌入式开发》

●专栏《Keil教程》

●嵌入式专栏精选教程

点击“阅读原文”查看更多分享。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

备战2024年上海初中生古诗文大会:单选题真题示例和独家解析

上海市中小学生的初中生古诗文大会——即上海中学生古诗文大会(初中组)和小学生古诗文大会(比赛)除了题型略有不同外,最主要的是考察的内容深度和广度不同,初中的题目中对于文言文的考察大幅增加&#xff0…

SpringBoot相关知识点总结

1 SpringBoot的目的 简化开发,开箱即用。 2 Spring Boot Starter Spring Boot Starter 是 Spring Boot 中的一个重要概念,它是一种提供依赖项的方式,可以帮助开发人员快速集成各种第三方库和框架。Spring Boot Starter 的目的是简化 Sprin…

C语言数据结构之顺序表

目录 1.线性表2.顺序表2.1顺序表相关概念及结构2.2增删查改等接口的实现 3.数组相关例题 1.线性表 线性表(linear list)是n个具有相同特性(数据类型相同)的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构&#xff…

【RV1106的ISP使用记录之基础知识】硬件连接关系与设备树的构建

RV1106具备2个mipi csi2 dphy硬件,1个VICAP硬件和1个ISP硬件。其中: 1、mipi csi2 dphy 用于对数据流的解析,支持MIPC,LVDS,DVP三种接口; 2、VICAP用于数据流的捕获; 3、ISP用于对图像数据进行处理; 这三个…

【QTM中文教程】01:Quick Terrain Modeller介绍、下载与安装

文章目录 一、Quick Terrain Modeller简介二、Quick Terrain Modeller特点功能三、Quick Terrain Modeller下载安装1. 下载地址2. 安装教程一、Quick Terrain Modeller简介 Quick Terrain Modeler(QTM)是一种专业的地形建模软件,用于处理和分析地形数据。它提供了一系列功能…

【漏洞复现】泛微e-cology ProcessOverRequestByXml接口存在任意文件读取漏洞

漏洞描述 泛微e-cology依托全新的设计理念,全新的管理思想。 为中大型组织创建全新的高效协同办公环境。 智能语音办公,简化软件操作界面。 身份认证、电子签名、电子签章、数据存证让合同全程数字化。泛微e-cology ProcessOverRequestByXml接口存在任意文件读取漏洞 免责声…

【漏洞复现】宏景eHR showmediainfo SQL注入漏洞

0x01 产品简介 北京宏景世纪软件股份有限公司(简称“宏景软件”)专注于国有企事业单位人力与人才管理数智化(数字化、智能化)产品的研发和应用推广。 0x02 漏洞概述 宏景eHR /workbench/duty/showmediainfo接口存在SQL注入漏洞…

Jenkins用maven风格build报错解决过程记录

1、Jenkins2.453新建项目,构建风格选的maven 2、自由风格构建部署没有任何问题,但是maven风格build一直失败,报错如下图 3、解决方案:在系统管理–系统配置–Maven项目配置,删除全局MAVEN_OPT的路径信息,…

oracle 清空回收站

参考官方文档 select * from user_recyclebin; select * from dba_recyclebin; ---清除回收站中当前用户下的对象 purge recyclebin; ---清除回收站中所有的对象 purge dba_recyclebin; ---清除回收站中指定用户的表 PURGE TABLE owner.table_name; ---清除回收站中指…

PSCAD|应用于输电线路故障测距的行波波速仿真分析

1 主要内容 该程序参考文献《应用于输电线路故障测距的行波波速仿真分析》,利用线路内部故障产生的初始行波浪涌达线路两端测量点的绝对时间之差值计算故障点到两端测量点之间的距离,并利用小波变换得到初始行波波头准确到达时刻,从而精准定…

HTML 入门 ( 一 )

HTML文档创建 首先创建一个txt文本文档 修改文件后缀 HTML标签 标签结构 标签又称为元素,是HTML的基本组成单位分为: 双标签与单标签推荐小写标签名 结构: 双标签示例代码: <marquee> My name is Kvein. </marquee>单标签示例代码: <input>标签的并列与嵌…

AndroidStudio右下角显示内存使用情况

目录 一.具体效果 二.4.0以下版本 三.4.0以上版本 四.增加内存配置 一.具体效果 二.4.0以下版本 1.打开 Android Studio. 2.进入设置界面。点击 Android Studio 左上角的“File”&#xff0c;然后选择“Settings” 3.在设置界面中&#xff0c;选择“Appearance & Beha…

汇编语言与x64函数参数传递

本节课学习视频&#xff1a;https://pan.quark.cn/s/429055967dfd 汇编语言作为编程语言与机器语言之间的桥梁&#xff0c;直接反映了硬件的工作方式。在不同的操作系统和硬件架构中&#xff0c;函数参数的传递方式可能有所不同。今天&#xff0c;我们将探讨x64位环境下函数参…

KDD‘23 | AlphaMix: 高效专家混合框架(MoE)显著提高上证50选股表现

KDD23 | AlphaMix: 高效专家混合框架&#xff08;MoE&#xff09;显著提高上证50选股表现 原创 QuantML QuantML 2024-04-18 09:17 上海 Content 本文提出了一个名为AlphaMix的新型三阶段专家混合&#xff08;Mixture-of-Experts&#xff0c;MoE&#xff09;框架&#xff0c;…

c++使用spdlog库打日记

打日记 打日志的本质就是多输出&#xff0c;c没有自带的日志库&#xff0c;只能使用第三方库实现&#xff0c;当然&#xff0c;直接cout输出也可以&#xff0c;但是一般日志库都进行了优化&#xff0c;比我们使用cout输出的效率更高&#xff0c;同时效果也更好&#xff0c;这里…

正大国际:什么是庞氏骗局?

在金钱的诱惑下&#xff0c;人性的贪婪与恐惧交织成一张无形的网&#xff0c;让无数人沉迷其中&#xff0c;无法自拔。这其中&#xff0c;庞氏骗局作为一种极具欺骗性的金融诈骗手段&#xff0c;更是将人们的贪婪与信任利用到了极致。那么&#xff0c;究竟什么是庞氏骗局呢&…

1096 大美数

solution B被A整除&#xff0c;B是A的倍数。B / AA整除B A把B整除 &#xff22;被A整除 B / A >n可以整除不同的四个因数之和 等价于 (a b c d) % n 0 #include<iostream> #include<cmath> using namespace std; int main(){int k, n, t;scanf("%d&q…

基于TCC的分布式事务

优质博文&#xff1a;IT-BLOG-CN 一、分布式事务简介 分布式的架构中&#xff0c;分布式的事务是一个绕不过的挑战&#xff0c;微服务理念的流行让分布式的问题日益突出。 在公司内部&#xff0c; 笔者所接触的管理系统中实际上也存在着分布式事务。 这里假设有这三个系统&…

Redis从入门到精通(二十二)Redis原理之数据结构、网络模型、通心协议、内存回收

文章目录 第8章 Redis原理8.1 Redis数据结构8.1.1 RedisObject8.1.2 动态字符串&#xff08;SDS&#xff09;8.1.3 string8.1.4 List8.1.5 Set8.1.6 ZSet8.1.7 Hash 8.2 Redis网络模型8.2.1 五种网络模型介绍8.2.1.1 用户空间和内核空间8.2.1.2 阻塞IO8.2.1.3 非阻塞IO8.2.1.4 …