- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
引言: 编写高效简洁的C语言代码,是许多软件工程师追求的目标。本文就工作中的一些体会和经验做相关的阐述,不对的地方请各位指教。 第一招:以空间换时间 计算机程序中最大的矛盾是空间和时间的矛盾,那么,从这个角度出发逆向思维来考虑程序的效率问题,我们就有了解决问题的第1招--以空间换时间。 例如:字符串的赋值。 方法A:通常的办法:
#define LEN 32char string1 [LEN];memset (string1,0,LEN);strcpy (string1,This is a example!!); 方法B:
const char string2[LEN] =This is a example!;char * cp;cp = string2 ; 使用的时候可以直接用指针来操作。 从上面的例子可以看出,A和B的效率是不能比的。在同样的存储空间下,B直接使用指针就可以操作了,而A需要调用两个字符函数才能完成。B的缺点在于灵活性没有A好。在需要频繁更改一个字符串内容的时候,A具有更好的灵活性;如果采用方法B,则需要预存许多字符串,虽然占用了大量的内存,但是获得了程序执行的高效率。 如果系统的实时性要求很高,内存还有一些,那我推荐你使用该招数。该招数的变招--使用宏函数而不是函数。举例如下: 方法C:
#define bwMCDR2_ADDRESS 4#define bsMCDR2_ADDRESS 17int BIT_MASK(int __bf) { return ((1U (bw ## __bf)) - 1) (bs ## __bf);}void SET_BITS(int __dst, int __bf, int __val){ __dst = ((__dst) ~(BIT_MASK(__bf))) | \ (((__val) (bs ## __bf)) (BIT_MASK(__bf))))}SET_BITS(MCDR2, MCDR2_ADDRESS, RegisterNumber); 方法D:
#define bwMCDR2_ADDRESS 4#define bsMCDR2_ADDRESS 17#define bmMCDR2_ADDRESS BIT_MASK(MCDR2_ADDRESS)#define BIT_MASK(__bf) (((1U (bw ## __bf)) - 1) (bs ## __bf))#define SET_BITS(__dst, __bf, __val) \((__dst) = ((__dst) ~(BIT_MASK(__bf))) | \(((__val) (bs ## __bf)) (BIT_MASK(__bf))))SET_BITS(MCDR2, MCDR2_ADDRESS, RegisterNumber); 函数和宏函数的区别就在于,宏函数占用了大量的空间,而函数占用了时间。大家要知道的是,函数调用是要使用系统的栈来保存数据的,如果编译器里有栈检查选项,一般在函数的头会嵌入一些汇编语句对当前栈进行检查;同时,CPU也要在函数调用时保存和恢复当前的现场,进行压栈和弹栈操作,所以,函数调用需要一些CPU时间。而宏函数不存在这个问题。宏函数仅仅作为预先写好的代码嵌入到当前程序,不会产生函数调用,所以仅仅是占用了空间,在频繁调用同一个宏函数的时候,该现象尤其突出。 D方法是我看到的最好的置位操作函数,是ARM公司源码的一部分,在短短的三行内实现了很多功能,几乎涵盖了所有的位操作功能。C方法是其变体,其中滋味还需大家仔细体会。 第二招:数学方法解决问题 现在我们演绎高效C语言编写的第二招--采用数学方法来解决问题。数学是计算机之母,没有数学的依据和基础,就没有计算机的发展,所以在编写程序的时候,采用一些数学方法会对程序的执行效率有数量级的提高。举例如下,求 1~100的和。 方法E
int I , j;for (I = 1 ;I=100; I ++){ j += I;} 方法F
int I;I = (100 * (1+100)) / 2 这个例子是我印象最深的一个数学用例,是我的计算机启蒙老师考我的。当时我只有小学三年级,可惜我当时不知道用公式 N×(N+1)/ 2 来解决这个问题。方法E循环了100次才解决问题,也就是说最少用了100个赋值,100个判断,200个加法(I和j);而方法F仅仅用了1个加法,1次乘法,1次除法。效果自然不言而喻。所以,现在我在编程序的时候,更多的是动脑筋找规律,
您可能关注的文档
- 社会工作概论第五章 [2].ppt
- 费列罗巧克力包装的策划案.doc
- 费率招标-模拟清单招标-工程量清单招标方式比较.doc
- 贺兰一中2013—2014学年第一学期备考组计划2.doc
- 社会心理学-亲密关系-爱情.ppt
- 社会核算矩阵政府财政核算及统计数据公布系统.ppt
- 贺州市高铁生态新城概念性总体规划和新城站前片区城市设计任务书.doc
- 贺进镇初中数学教学情况分析及评价报告.doc
- 社区诊断流程和方法.ppt
- 指导学生课阅外读心得.doc
- 跨境电商独立站本土化物流配送模式研究报告.docx
- 2025年合成生物学在食品添加剂中的应用与市场前景分析报告.docx
- 白酒市场高端消费者饮酒场景与品牌形象塑造报告.docx
- 2025年执业药师之《西药学综合知识与技能》精选试题带答案详解(研优卷).docx
- 2025年航空维修企业MRO数字化管理系统运维管理指南报告.docx
- 2025年航空氢能源安全性与环保性能评估报告.docx
- 2025年有声读物市场5G技术对内容创作的影响研究报告.docx
- 农业温室环境监测系统2025年智能化升级的产业竞争力分析.docx
- 城市快速路建设项目2025年社会稳定风险评估与风险评估指标体系优化报告.docx
- 智能交通车辆检测技术对公共交通的影响报告2025.docx
文档评论(0)