点击上方蓝字关注我哦~

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

总结

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

全局变量一定是要用的,管理它们也很重要。一些基本的代码规则:

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

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

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

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

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

/ The End /

推荐阅读

嵌入式技术学习路线

从单片机工程师的角度看嵌入式Linux

真的可以,用C语言实现面向对象编程OOP

免责声明:本文转载自知乎,版权归原作者所有。如涉及作品版权问题,请与我联系删除。

扫码关注我们

看更多嵌入式案例

linux 库全局变量_C语言开发单片机为什么大多数都采用全局变量的形式?相关推荐

  1. c 多文件全局变量_C语言开发单片机为什么大多数都采用全局变量的形式?

    点击上方蓝字关注我哦- 01 前言 全局变量简直就是嵌入式系统的戈兰高地.冲突最激烈的双方是1. 做控制的工程师 2. 做非嵌入式的软件工程师. 02 做控制的工程师特点 他们普遍的理解就是" ...

  2. 单片机全局有必要封装_C语言开发单片机为什么大多数都采用全局变量的形式?...

    全局变量简直就是嵌入式系统的戈兰高地.冲突最激烈的双方是1. 做控制的工程师 2. 做非嵌入式的软件工程师. 第一派做控制的工程师.他们普遍的理解就是"变量都写成全局该有多方便". ...

  3. C语言开发单片机为什么大多数都采用全局变量的形式?

    一个代码狗,成长经历都是莫名相似的. 你应该和我有类似的经历,虽然功能都能做出来,但是总觉得自己代码缺了点什么. 就是怎么写都觉得不够完美,感觉代码的水平介于专业和不专业之间. 自己的认知水平也非常有 ...

  4. c 多文件全局变量_C语言开发单片机为啥都是全局变量形式?

    01 前言 全局变量简直就是嵌入式系统的戈兰高地.冲突最激烈的双方是:1. 做控制的工程师:2. 做非嵌入式的软件工程师. C语言.单片机.嵌入式相关资料,可以加我微信"dqjob12345 ...

  5. 第4章 Linux下的C语言开发基础

    第4章 Linux下的C语言开发基础 4.1 C语言开发的基本步骤 C语言源程序开发的基本步骤如下: 根据项目需求划分功能模块 编辑.利用文本编辑器vi或gedit编写C源程序并保存,文件的后缀为.c ...

  6. linux下的C语言开发

    在很多人的眼里,C语言和linux常常是分不开的.这其中的原因很多,其中最重要的一部分我认为是linux本身就是C语言的杰出作品.当然,linux操作系统本身对C语言的支持也是相当到位的.作为一个真正 ...

  7. c开发 易语言支持库,易写易库-用易语言开发易语言支持库.pdf

    易写易库-用易语言开发易语言支持库 易写易库(EXEK)用户手册 版本:0.2 作者:liigo,/liigo 时间:2008.10 概述 EXEK EXEK "易写易库(EEXXEEKK) ...

  8. 为什么大家都用C语言开发单片机,原因都在这啦

    提起单片机开发,就不得不说C语言,它是一门面向过程的.抽象化的通用程序设计语言,广泛应用于底层开发.那为什么大家都用C语言来开发单片机呢?原因都在这里了!下面通程创品就给大家简单介绍下. 为什么大家都 ...

  9. linux系统最好的c类语言开发软件,Linux下基于C 语言开发即时通信软件.doc

    Linux下基于C 语言开发即时通信软件 Linux下基于C++语言开发即时通信软件 关键词:聊天软件 文字聊天 Linux平台 C/S架构ICE中间件 Linux-based instant mes ...

最新文章

  1. Hive学习之路 (九)Hive的内置函数
  2. Knative 基于流量的灰度发布和自动弹性实践
  3. java找哪一天是星期几_七夕节是几月几日农历时间 2019年七夕情人节哪一天星期几...
  4. 2017c 语言程序设计,C语言程序设计第一次作业(2017.10.10完成)
  5. pdf阅读器下载支持win7_福昕PDF阅读器(Foxit Reader)下载|福昕PDF阅读器(Foxit Reader) 9.6.1.25160 官方版...
  6. php curl 获取 邮箱通讯录 sns(hotmail)
  7. [蓝桥杯2016初赛]方格填数-next_permutation
  8. insert into select 优化_数据库优化总结
  9. 牛逼!简单的代码提交能玩出这么多花样
  10. 获取今天是星期几的四种写法
  11. GuzzleHttp使用
  12. 甲骨文UBUNTU安装宝塔面板无法访问
  13. java 实现秒抢_Java实现抢红包算法,附完整代码(公平版和手速版)
  14. 魔方(9)四轴枫叶魔方、四轴斜转魔方
  15. 如何在Django后台添加pagedown
  16. Linux RPM包安装、卸载和升级(rpm命令)详解
  17. 日期时间选择插件 - laydate.js
  18. Spring是什么?IoC容器的理解
  19. 《癌症·真相》读书简摘
  20. [RK3288] AP6335WIFI模块移植(板级dts文件代码编写)

热门文章

  1. 人类和海洋动物的相似之处
  2. 面对毕业季,无经验应届生如何顺利找到运营工作(下)
  3. visual画图软件_历史最全科技互联网类免费书籍、音乐、照片、软件、招聘信息整理汇总分享...
  4. VIVADO 自定义封装ip核(超详细)
  5. 【Python】经典问题创建一个矩形类,定义方法 属性 初始化
  6. java调用word模板文件_Java使用模板导出word文档
  7. Django 教程之数据库模型
  8. Coco2d-x 3.x : Cocos Studio 制作的UI无法正确显示,出现绿色或白色底
  9. 攻防世界 logmein wp
  10. 如何实现上传多个图片并依次展示_如何在一页PPT中插入多张图片,并保持其美感...