如何为嵌入式应用编写优秀的C 代码

2008-02-23 05:28:18来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

在嵌入式软件技术中,C 语言具备较高的编程效率。但是,要实现高效率,更有许多问题需要特别注意。首先,应该正确理解C 的工作原理,逐步利用他的各种强大功能,把专业经验集成到对象中,并使用针对嵌入式应用做过优化的研发工具。不建议使用纯粹的自顶向下的设计策略和深层嵌套继承,并避免为适应工具而放弃语言功能,而使编程的效率降低。

嵌入式软件技术似乎落后于新的发展形势,这主要是因为嵌入式研发人员根据多年来应付有限资源的经验而养成了谨慎保守的态度。这里所指的有限资源包括:存储器容量很有限,CPU的功能只是刚好够用。

对编程语言的选择完全反映了这种实用保守主义态度。数年前,嵌入式研发人员慢慢开始熟悉高级语言,但最终被接受的是C语言。为了促使业界接受, C语言具备很高质量的代码生成和透明调试功能,另一方面,也正是在巨大的压力下C语言才变得更有效率。

即使相对于C,C 取得了明显的改进,但他在嵌入式系统中的应用仍远未普及。

造成这种犹豫不决的原因倒不是因为人们固执地拒绝改变,而是很简单,他们还是担心资源问题。存储器可能是大了一些,但您不可能随心所欲地额外增加500兆字节容量;处理器速度也确实快了很多,但成本和功耗限制决定了他们的功能远远比不上即使是最普通的台式机中的处理器那么强大。

按这种思路对C 用于嵌入式软件的适当性产生顾虑又是否合理呢?答案是不一定。就像任何工具那样,只有正确合理地使用语言,才能产生良好的结果。

建议

开始逐步使用C 。假如设计师今天还在使用C,那么让他明天就使用C 肯定是个极大的跨越。然而,由于C 并不是一种面向对象的语言(实际上他是具备某些面向对象特点的一种过程语言),并且基本上是C的一个超集,因此设计师能够逐步发掘C 新增的强大功能。

理解C 的实际工作原理。查看生成的代码,并试着理解为什么要按他那样的方式做。

在对象中集成专业经验。嵌入式软件研发小组成员会有各种编程技巧,将这些专业经验集成到一些类(class)里面,从而能让其他团队成员安全地共享这些专业经验。

使用针对嵌入式应用做过优化的设计工具。虽然许多公司提供嵌入式编程工具,但相对而言,一些工具更能满足嵌入式研发者的实际需求。

适当应用语言功能。C 并不是专门针对嵌入式应用而研发的语言。某些语言特性,比如过载功能,绝不会消耗任何资源。而其他特性,如异常处理系统(EHS),则可能需要很大的开销。该功能能够帮助编程人员构建极具鲁棒性的代码。但缺点是为了适应这种功能,工具会在后台悄悄地产生大量的代码。假如这种情况不可避免,那么至少以简单的方式使用EHS将能减少意外发生。

不建议

将嵌入式系统当作PC。假如设计师在对PC进行编程,那么能够认为存储器是无限和随便使用的,并且总是有足够的CPU处理能力。但在编写嵌入式软件时需要更加谨慎。先编一些代码,看看他的长度和执行性能。然后,只有当测试结果位于合理范围内而使设计师满意时,才能继续做下去。

图1:在嵌入式系统中,存储器一直是珍贵的资源。一个支持智能链接的链接器能利用编译器产生输出来消除重复的存储器区域。

使用纯粹的至顶向下的实现方法。从高层开始,创建只包括低层功能stub程式的软件应用程式创建是很吸引人的。然而,这种策略的缺点在于会出现很多令人讨厌的意外问题。设计师可能在编写完代码后发现整个程式太大或太慢,甚至又大又慢。

使用深层嵌套的继承(inheritance)。面向对象编程方法的长处之一是能够让设计师自己或其他研发人员根据以前创建的其他基础类定义新的类,并且不用完全理解那些基础类的内部工作机理。这就是继承。但这样做的缺点是根据这种方式生成的类的实例化对象可能需要一定的开销。

编写“聪明的”代码。研发人员能够用C 写出很聪明简洁的代码。但C 也能让人写出相当晦涩难懂的代码。千万不要是后者。

仅仅因为工具不能很好地处理而放弃一些语言功能。例如,假如模板实现很差,他们就会产生严重的代码膨胀(code bloat)。假如工具不能很好地处理这种情况,那就改用别的能够帮助提高编程效率的工具。




标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: Bjarne:什么是函数对象?

下一篇: 多边形和剪贴区域

热门词条
热门标签