0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

C语言开发单片机为啥都是全局变量形式?

GReq_mcu168 来源:玩转单片机 2020-08-05 10:35 次阅读

前言

全局变量简直就是嵌入式系统的戈兰高地。冲突最激烈的双方是:

1. 做控制的工程师

2. 做非嵌入式的软件工程师。

做控制的工程师特点

他们普遍的理解就是“变量都写成全局该有多方便”。我之前面试过一个非常有名的做控制实验室里出来的PhD/Master,前前后后陆续有快十个人。面试问题是用C写PID。到后面的几位面试的时候我都觉得没有看的意义了,因为全都写的是同一个风格。大概就是这样的:

float SetSpeed;float err;float err_last;float Kp,Ki,Kd;float integral;float result; float PID(float speed){ err=SetSpeed-speed; integral+=err; result=Kp*err+Ki*integral+Kd*(err-err_last); err_last=err; return result;} 代码的特点就是所有的变量一定定义在函数外面。问他们为什么,回答是“全局变量方便调试”。 事实上在学校里做搞自动控制的人最重要的根本就是控制的结果,而不是代码本身。代码只要能工作就行。变量名污染,低耦合之类的和他们就不在同一个世界。进了公司有些人代码质量会变好,但有的还是会延续之前的习惯。前公司代码库里面凡是看不懂的代码一律都是那一两个Control Engineer写的,写完了还会用自己的名字给函数命名的那种。 要成为一个资深的嵌入式工程师相当难,一方面要有非常扎实的理论知识,同时也要有相当的那种大型的、高频CPU、多层PCB板的设计经验。嵌入式硬件工程师要学的课程主要有模拟电路设计数字电路设计、电磁波理论等。熟悉常用的放大电路、滤波电路、电源电路设计和分析。

做非嵌入式的软件工程师特点

代码的特点就是所有的静态变量都不可以定义在.h文件里,必须写在.c文件里以确保别的文件没法访问它们。 别的文件真要访问怎么办?那就给每一个变量写get/set函数啊!问题是静态变量写在.c文件里编译器是没法优化get/set的。结果就大面积的变量访问要花几倍的CPU时间去做get/set的函数调用。嵌入式项目很多情况下对硬件的压榨是很极端的,CPU利用率90%都不算什么,顶到97%都是有的。(注意下这些项目是实时性要求很高的,晚一个毫秒算不完都不行。不是跑在电脑上鼠标卡一卡也无所谓的。)然后为了封装性,在代码里面塞这么多get/set吗?

总结

总的来说嵌入式软件里大部分的代码都是中断驱动的,天生就有很多变量是没法使用参数传递的。全局变量的存在是因为正义站在这边。但是嵌入式软件远远没有特殊到不需要按照正常软件工程方法去管理的地步。要真有人认为“嵌入式软件只要能工作就成,代码丑一点无所谓的”纯粹是软件工程水平不行,不是因为控制水平太高。 全局变量一定是要用的,管理它们也很重要。一些基本的代码规则:

如果只是文件内调用,全局变量只能写在这个.c文件里,不要写进.h文件。

如果有文件外调用,全局变量要写在.h文件里。

.h里面的全局变量全局可读,但是只有本文件组可以写。别的文件要写请调用set函数。

所有的全局变量无论在.h还是.c里面都要包成同名struct。哪怕只有一个变量也要写进struct里面。比如PID.c里面有一个pid_S,PID.h里面有个PID_S。这样其他人不仅可以立即识别出一个变量是project内global/文件内static/函数内local,同时还能轻松追溯到这个函数是属于哪个文件的。

不要写函数内的static变量。函数内的static变量在实际的项目中几乎就是bug生成器,没法简单的reset。而且对unit test非常不友好。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    4981

    文章

    18266

    浏览量

    288217
  • C语言
    +关注

    关注

    180

    文章

    7527

    浏览量

    128152
  • 代码
    +关注

    关注

    30

    文章

    4554

    浏览量

    66720

原文标题:C语言开发单片机为啥都是全局变量形式?

文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    你用过哪些编程语言开发单片机

    C语言是最常用的一种用于单片机开发语言,也是一种高级编程语言,具有较好的可移植性和可读性。对于单片机
    发表于 12-04 10:18 328次阅读

    全局变量数组数据错乱怎么解决?

    不知道是自己定义的全局变量太多了还是怎么了? 在执行数组赋值的时候不同的全局变量会出现共用地址的问题,也就是明明在给A赋值但是B的值也一起变了?导致出现数据错乱,不知有谁遇到过这种情况???
    发表于 11-06 08:19

    STM8L进入低功耗全局变量释放的原因?

    做一项目,使用RTC闹钟唤醒功能唤醒,测试了两个月,没遇到全局变量释放的情况。今天上午发现单片机不能在指定时间唤醒,仿真模式下找了原因,发现使用的数组在进入休眠后,十分钟唤醒后,数组释放掉了,数组是全局变量。 向大神请教原因。
    发表于 11-03 08:18

    C语言中定义全局变量时,如何在定义变量时就指定好变量的地址?

    请问,C语言中定义全局变量时,如何在定义变量时就指定好变量的地址?
    发表于 11-03 06:31

    请问C语言和汇编语言开发单片机时各有哪些优缺点?

    C语言和汇编语言开发单片机时各有哪些优缺点?
    发表于 10-30 06:32

    嵌入式全局变量的初始化原理详解

    全局变量的初始值,是在哪里赋值的?
    的头像 发表于 10-27 10:15 645次阅读
    嵌入式<b class='flag-5'>全局变量</b>的初始化原理详解

    请问C语言和汇编语言开发单片机时各有哪些优缺点?

    C语言和汇编语言开发单片机时各有哪些优缺点?
    发表于 10-26 07:47

    C++开发单片机有哪些优势和劣势呢?

    在一般的IDE里面除了C可以选择还有很多常见的C++,C++开发单片机有哪些优势和劣势?
    发表于 10-16 07:30

    labview全局变量不能用,接收不到数值

    我在labview程序里面加入一个全局变量,如图所示,用light1指示是有变化的,但是全局变量无变化,像是接收不到数值? 是因为我是在FPGA里面用的吗?FPGA里面不能用全局变量吗?
    发表于 07-31 21:43

    嵌入式C编程中全局变量问题分享

    嵌入式特别是单片机os-less的程序,最易范的错误是全局变量满天飞。这个现象在早期汇编转型过来的程序员以及初学者中常见,这帮家伙几乎把全局变量当作函数形参来用。
    发表于 07-17 16:53 517次阅读

    RTOS任务间通信为什么不用全局变量

    RTOS任务间通信为什么不用全局变量?原因在于使用全局变量存在诸多弊端。
    发表于 07-05 09:06 420次阅读

    static的全局变量与局部变量的使用,看完你就懂了

    全局变量有许多缺点,最明显的缺点是破坏了此变量的访问范围(使得在此函数中定义的变量,不仅仅只受此函数控制)。static 关键字则可以很好的解决这个问题。 另外,在 C++ 中,需要一
    发表于 06-27 08:54

    第69集13.3#100)局部变量全局变量的家(堆栈):你了解吗?

    全局变量
    于振南的单片机世界
    发布于 :2023年06月14日 13:45:12

    求助,保存的全局变量在哪里?

    我有一个关于全局变量的新手问题。我们定义是否将代码保存到 RAM 或 FLASH 中,并带有函数属性。但是全局变量(在函数外部定义的)存储在哪里?也可以更改存储它们的位置吗?
    发表于 06-12 07:31

    MCUXPresso IDE加载全局变量时间过长怎么解决?

    当我进入调试模式并且我想观察一个全局变量时,我打开“全局变量”视图。 “Loading global variables from build artifacts”花费的时间太长,而且在它完成之前什么也做不了。 每次我打开“全局变量
    发表于 05-17 07:04