嵌入式编程与c语言有何区别,有的嵌入式设备也提供C++编译器,那还有理由坚持使用C语言吗?...

在嵌入式软件程序开发中,C语言无疑是最常被使用的程序语言。不过应该明白的是,有些嵌入式硬件同时提供C语言程序编译器以及C++程序编译器,而相比于C语言,C++的确具备很多非常好用的特性。

8e1413f47c4ff238b1dbe56b3f350511.pngC++更好用?

C++更好用?

小明是一名嵌入式软件工程师,他擅长C语言和C++编程,现在需要在一款提供C++和C89编译器的4KB RAM 硬件设备上进行程序开发,他觉得C++有下面这些好用的特性:

C++支持inline函数,它比define宏定义安全许多。C++支持命名空间(namespaces)。C++因为有模板和很多类型转换,因此类型安全性比C语言好。C++支持函数重载。小明还有理由坚持只使用C89进行程序开发吗?

0c4f8c47cfa0bb453ba758bd777fc69d.png还有理由坚持只使用C89进行程序开发吗

讨论

对于资源有限,比如RAM只有4KB的设备,我通常在正式开发C语言程序之前,会先写一些样例试水。天下没有免费的午餐,C++的一些好用特性其实是以牺牲性能为代价换来的,例如RTTI,动态类型转换,多重继承,多态以及异常处理都会带来一定的运行时开销。

另外,在嵌入式环境中,通常需要在硬件设备可以正常使用之前对其初始化,如果没有操作系统或者引导加载程序,这些初始化工作需要由程序员编写的程序完成。

应该明白的是,C++程序中的全局对象的构造函数是在 main() 之前运行的,因此在某些情况下,程序员将不得不修改本地的CRT0.S,以便在调用全局构造函数之前完成硬件的初始化。

3ee072761480c5424a47d6f7ef8a9772.png在调用全局构造函数之前完成硬件的初始

因此,如果希望使用C++方便的进行嵌入式程序开发,最好限制使用C++的一些开销较大的高级特效。但是使用C++进行C语言风格的程序开发,倒不如直接使用C语言了。

此外,使用C语言进行嵌入式程序开发更容易把控最终生成的指令,能够得到更精确的硬件控制,这对于资源匮乏的嵌入式设备来说是非常可贵的。尤其在RAM只有4KB的设备上开发程序,使用C++要小心很多细节,反而没有使用C语言方便了。

还有种情况需要考虑,就是很多嵌入式设备并不提供C++编译器,因此虽说大多数优秀的C语言程序员使用C++没有什么问题,但是相比较而言,他们(包括我)更了解C语言,知道每一行代码究竟会做哪些工作,以及开销如何,这对于开发使用更小开销实现更大效率的程序很有帮助。

995e03bcefe5a940cad3518b62605fb8.png使用更小开销实现更大效率

C语言语法比C++语法简单的多,也正因为如此,甚至很多程序员认为C语言是低级语言。正如前面所讨论的,C语言的每一行代码的意义都很明确,这使得C语言程序员把自己的精力主要花费在在硬件和构建良好的的和数据结构以及算法上,而复杂的C++则会让程序员花费大量时间挠头,想知道里面发生了什么,以及为什么不能在特定的环境和背景下做一些完全合理的事情,而只能服从编译器。

简单来说,C语言程序更加可控,而嵌入式程序员一般都是控制欲很强的性格,从这一层面考虑,C语言也更加适合嵌入式程序开发。

d54527442883b0fd0fcca8d648ad4160.pngC语言也更加适合嵌入式程序开

小结

简单来看,在嵌入式程序开发领域,C语言比C++更加合适主要有两个原因:

1. C语言程序更好预测其代码尺寸和开销,这对于RAM只有4KB的资源匮乏的嵌入式设备来说来很重要。

2. 大多数嵌入式程序员更了解C语言,因此为了促进同事间的协调性,更推荐使用大家都喜爱的程序语言。

3b478cb8ff84a6194ca3e1182ccc9427.png点个关注再走吧

欢迎在评论区一起讨论,质疑。文章都是手打原创,每天最浅显的介绍C语言、linux等嵌入式开发,喜欢我的文章就关注一波吧,可以看到最新更新和之前的文章哦。

未经许可,禁止转载。

举报/反馈

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值