老古开发网首页
导航:老古开发网首页文章索引文章分类另类其他→[如何为嵌入式应用编写优秀的C++代码]
| -文章搜索 - 最新文章 - |

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

发布时间:2007年3月15日 点击次数:9
来源:电子产品世界   作者:
 

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

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

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

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

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

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

建议

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

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

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

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

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

不建议

将嵌入式系统当作PC。如果设计师在对PC进行编程,那么可以认为存储器是无限和随便使用的,并且总是有足够的CPU处理能力。但在编写嵌入式软件时需要更加谨慎。先编一些代码,看看它的长度和执行性能。然后,只有当测试结果位于合理范围内而使设计师满意时,才能继续做下去。
 [ 相关贴图 ]
screen.width-430)this.width=screen.width-430" align=center border=0>
图1:在嵌入式系统中,存储器一直是珍贵的资源。一个支持智能链接的链接器能利用编译器产生输出来消除重复的存储器区域。
 


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

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

编写“聪明的”代码。开发人员可以用C++写出非常聪明简洁的代码。但C++也能让人写出相当晦涩难懂的代码。千万不要是后者。

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


欢迎进入老古论坛进行讨论
[另类其他] 相关文章:
电子工程师的程序人生历程
简介:
这些日子我一直在写一个实时操作系统内核,已有小成了,等写完我会全部公开,希望能 够为国内IT的发展尽自己一份微薄的力量。最近看到很多学生朋友和我当年一样没有方向 ,所以把我的经历写出来与大家共勉,希望能给刚如行的朋友们一点点帮助。 一转眼我在IT行业学习工作已经七年多了,这期间我做过网页,写过MIS、数据库,应 用程序,做过通信软件、硬件驱动、协议栈,到现在做操作系统内核和IC相关开发,这中 间走了很多弯路,也吃了不少苦。 我上的是一个三流的高校,就连同一个城市的人多数都不知道。因为学校不好也就没 有指望能靠学校名气找一......

3月里来跳槽忙 太多跳槽经历可能成负担
“销售主管”是推销员 网络招聘四陷阱
国内外EAD软件介绍
自动控制专业词汇
联合国推动制订电子废弃物循环利用国际标准
日本語電気専門用語辞書E
键盘驱动开发
初学者编程最简练的指导
求职英语:如何自我推销
 
下一个:[另类其他]电子爱好者常备的工具和材料
简介:
万用表:也叫多用表。一般可用于电压、电流、电阻的测量。有的还具有电容、电感、频率测量等功能。 电烙铁:这个不用多说,主要是用来焊接元器件,有时也拿来烫烫硅胶或者塑料什么的。根据加热元件的位置,电烙铁有外热式和内热式之分。也有带吸锡功能的电烙铁。 焊锡:焊接用的连接剂。焊锡一般是中空的,中间充满松香。 吸锡器:用于拆卸零件时,清除焊盘上的焊锡。 松香:助焊剂。帮助焊接,使焊点牢固、光滑、光亮。 注射器针头:可用于拆卸管脚数量较多的零件,象DIP封装的IC等。 酒精:酒精是很好的有机溶剂。常用来清洗元件、电路板等。把松香溶解到酒精里,就制成了松香水......
 

上一个:[新闻热点]信产部详解电子产品污染控制细则

老古开发网版权所有 2006年9月 asp.Net V2.0 设计:老古
页面缓存:10分钟 执行时间:16毫秒