c 多文件全局变量_C语言开发单片机为什么大多数都采用全局变量的形式?
点击上方蓝字关注我哦~
01
前言
全局变量简直就是嵌入式系统的戈兰高地。冲突最激烈的双方是1. 做控制的工程师 2. 做非嵌入式的软件工程师。
02
做控制的工程师特点
他们普遍的理解就是“变量都写成全局该有多方便”。我之前面试过一个非常有名的做控制实验室里出来的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板的设计经验。嵌入式硬件工程师要学的课程主要有模拟电路设计、数字电路设计、电磁波理论等。熟悉常用的放大电路、滤波电路、电源电路设计和分析。
03
做非嵌入式的软件工程师特点
代码的特点就是所有的静态变量都不可以定义在.h文件里,必须写在.c文件里以确保别的文件没法访问它们。
别的文件真要访问怎么办?那就给每一个变量写get/set函数啊!问题是静态变量写在.c文件里编译器是没法优化get/set的。结果就大面积的变量访问要花几倍的CPU时间去做get/set的函数调用。嵌入式项目很多情况下对硬件的压榨是很极端的,CPU利用率90%都不算什么,顶到97%都是有的。(注意下这些项目是实时性要求很高的,晚一个毫秒算不完都不行。不是跑在电脑上鼠标卡一卡也无所谓的。)然后为了封装性,在代码里面塞这么多get/set吗?
04
总结
总的来说嵌入式软件里大部分的代码都是中断驱动的,天生就有很多变量是没法使用参数传递的。全局变量的存在是因为正义站在这边。但是嵌入式软件远远没有特殊到不需要按照正常软件工程方法去管理的地步。要真有人认为“嵌入式软件只要能工作就成,代码丑一点无所谓的”纯粹是软件工程水平不行,不是因为控制水平太高。
全局变量一定是要用的,管理它们也很重要。一些基本的代码规则:
如果只是文件内调用,全局变量只能写在这个.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非常不友好。
/ The End /
推荐阅读
嵌入式技术学习路线
从单片机工程师的角度看嵌入式Linux
真的可以,用C语言实现面向对象编程OOP
免责声明:本文转载自知乎,版权归原作者所有。如涉及作品版权问题,请与我联系删除。
扫码关注我们
看更多嵌入式案例
c 多文件全局变量_C语言开发单片机为什么大多数都采用全局变量的形式?相关推荐
- linux 库全局变量_C语言开发单片机为什么大多数都采用全局变量的形式?
点击上方蓝字关注我哦- 01 前言 全局变量简直就是嵌入式系统的戈兰高地.冲突最激烈的双方是1. 做控制的工程师 2. 做非嵌入式的软件工程师. 02 做控制的工程师特点 他们普遍的理解就是" ...
- 单片机全局有必要封装_C语言开发单片机为什么大多数都采用全局变量的形式?...
全局变量简直就是嵌入式系统的戈兰高地.冲突最激烈的双方是1. 做控制的工程师 2. 做非嵌入式的软件工程师. 第一派做控制的工程师.他们普遍的理解就是"变量都写成全局该有多方便". ...
- C语言开发单片机为什么大多数都采用全局变量的形式?
一个代码狗,成长经历都是莫名相似的. 你应该和我有类似的经历,虽然功能都能做出来,但是总觉得自己代码缺了点什么. 就是怎么写都觉得不够完美,感觉代码的水平介于专业和不专业之间. 自己的认知水平也非常有 ...
- c 多文件全局变量_C语言开发单片机为啥都是全局变量形式?
01 前言 全局变量简直就是嵌入式系统的戈兰高地.冲突最激烈的双方是:1. 做控制的工程师:2. 做非嵌入式的软件工程师. C语言.单片机.嵌入式相关资料,可以加我微信"dqjob12345 ...
- 为什么大家都用C语言开发单片机,原因都在这啦
提起单片机开发,就不得不说C语言,它是一门面向过程的.抽象化的通用程序设计语言,广泛应用于底层开发.那为什么大家都用C语言来开发单片机呢?原因都在这里了!下面通程创品就给大家简单介绍下. 为什么大家都 ...
- c语言遍历文件内容_C语言学习第28篇---动态内存分配剖析
为什么C语言要动态分配内存的意义? 1.C语言中的一切操作都是基于内存的 2.变量和数组都是内存的别名 ---内存分配由编译器在编译期间决定的 ---定义数组的时候必须指定数组长度 ---数组长度是在 ...
- c语言小游戏 精简_C语言开发简易版扫雷小游戏
C 语言开发简易版扫雷小游戏 本文给大家分享的是一个使用 C 语言开发的命令行下的简易版扫雷小游戏, 本身没有什么太 多的技术含量, 只不过是笔者的处女作, 所以还是推荐给大家, 希望对大家学习 C ...
- c语言创造的文件保存路径_c语言怎么把变量写入文件路径
1. c语言 如何将变量写入文件 比如写入 c盘下面的test.txt文件中. #include #include void main(void) { char achBuf[256]; memset ...
- c语言开发与游戏时间,都9012年了,为何我用C语言开发游戏(是的,C语言)
原标题:都9012年了,为何我用C语言开发游戏(是的,C语言) 作者:Jonathan Whiting 原文:https://jonathanwhiting.com/writing/blog/game ...
最新文章
- python3 编写守护进程程序思路
- 快速查看Gradle项目的类库依赖情况
- 华为2017java笔试题_2017年java华为面试题
- mysql1033错误存储引擎_MySQL Innodb存储引擎因为缓存配置出现的错误
- #033 信安培训基础题Python解决网络安全实验室|网络信息安全攻防学习平台
- 微软称 SolarWinds 黑客还在继续攻击 IT 企业
- A study on ILC for linear discrete systems with single delay
- Python实现空间直角坐标转高斯克吕格平面坐标
- 吃鸡ios和android灵敏度,吃鸡手游pc版怎么调灵敏度参数教程 | 手游网游页游攻略大全...
- 航摄像片生成DSM(Pix4d)2021.5.21
- AM335x TP驱动解析
- Chapter6 机器人系统仿真(Ⅰ)---使用rviz集成urdf、xacro建造机器人模型
- 喝咖啡有什么好处和坏处?
- 实验六 视图的创建与管理
- TopCoder SRM 678 Div2
- CAS号:60535-02-6,二肽Met-Trp
- 红孩儿编辑器的模块设计8
- C# 程序集(Assembly)
- JavaScript,css时间计时器
- 汇编指令 BCC/BLO
热门文章
- top、postop、scrolltop、scrollHeight、offsetHeight
- 我的作品-图书馆信息管理系统
- [导入]Ajax初试
- JS_01JavaScript基础笔记
- Lucene-01 全文检索基本介绍
- 【剑指offer】面试题26: 树的子结构(Java)
- Leetcode--714. 买卖股票的最佳时间含手续费
- 中柏平板u盘启动_中柏电脑如何设置BIOS U盘启动
- rust矿洞绳子怎么爬下_rust矿洞绳子怎么爬下_打工小伙爬冰救人,每动一下都能听到冰面碎裂声...
- python编程购物车_python编写购物车新写法