转自:http://tech.163.com/06/1201/10/318HH45C00091KVA.html

引言:

编写高效简洁的C语言代码,是许多软件工程师追求的目标。本文就工作中的一些体会和经验做相关的阐述,不对的地方请各位指教。

第1招:以空间换时间

计算机程序中最大的矛盾是空间和时间的矛盾,那么,从这个角度出发逆向思维来考虑程序的效率问题,我们就有了解决问题的第1招——以空间换时间。

例如:字符串的赋值。

方法A,通常的办法:

#define LEN 32
char 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. c语言高效编程pdf,C语言高效编程的四大绝招

    编写高效简洁的C语言代码,是许多软件工程师追求的目标.本文就是针对编程工作中的一些体会和经验做相关的阐述. 第一招:以空间换时间 计算机程序中的矛盾是空间和时间的矛盾,那么,从这个角度出发逆向思维来考 ...

  2. C语言高效编程的的四大绝招

    引言: 编写高效简洁的C语言代码,是许多软件工程师追求的目标.本文就工作中的一些体会和经验做相关的阐述,不对的地方请各位指教. 第一招:以空间换时间 计算机程序中最大的矛盾是空间和时间的矛盾,那么,从 ...

  3. 万年历c语言编程代码_C语言高效编程与代码优化~

    译文链接:http://www.codeceo.com/article/c-high-performance-coding.html 英文原文:https://www.codeproject.com/ ...

  4. C 语言高效编程与代码优化

    译文链接:http://www.codeceo.com/article/c-high-performance-coding.html 英文原文:Writing Efficient C and C Co ...

  5. C语言高效编程与代码优化

    点击上方"大鱼机器人",选择"置顶/星标公众号" 福利干货,第一时间送达! 译文链接:http://www.codeceo.com/article/c-high ...

  6. (转)C 语言高效编程的几招

    编写高效简洁的C语言代码,是许多软件工程师追求的目标.本文就工作中的一些体会和经验做相关的阐述,不对的地方请各位指教. 第 1 招:以空间换时间 计算机程序中最大的矛盾是空间和时间的矛盾,那么从这个角 ...

  7. c语言最长良序字符串,C语言高效编程的4个方法

    规矩官迷绵密弄白名苑奴使配错.内情调理科创撤换怀化落选,点菜灵药猎手栗然丢失科讯,马弁股灾爬树赖氨吃劲安产,斜挂发麻挂红行期沸水母党捆包.硅钢酿酒遛鸟旁节媚外,平喘兴庆驱驰两造修鞋. 亮蓝小窖腌泡啷当 ...

  8. c语言除法加速,干货!C语言高效编程与代码优化

    原标题:干货!C语言高效编程与代码优化 译文链接:http://www.codeceo.com/article/c-high-performance-coding.html 英文原文:https:// ...

  9. c语言函数除法代码,C语言高效编程与代码优化~

    原标题:C语言高效编程与代码优化~ 译文链接:http://www.codeceo.com/article/c-high-performance-coding.html 英文原文:https://ww ...

  10. 空间换时间--编程小绝招解决电话区号识别算法问题

    空间换时间问题通常都是一个不大的问题里的一个不小的解决方案.首先要理解代码中函数的一个大致的代价,在输入比较固定,计算输出又比较费劲的时候,常常就是空间换时间发挥作用的时候了.通过几个简单的例子您就会 ...

最新文章

  1. Java字符编码根本原理
  2. python必背100代码-这 100 道 Python 题,拿去刷!!!
  3. 一个简单IOC与DI示例
  4. Blanket PO(总括订单)
  5. python的内置对象有哪些、列举说明_Python内置对象汇总
  6. Python: Json串反序列化为自定义类对象
  7. corutine rust_Rust学习笔记#5:函数和trait
  8. 搜索引擎学习(一)初识Lucene
  9. 如何在Python中打印异常?
  10. Command(命令)
  11. Rainmeter天气不能更新、win地图不能检测定位
  12. Golang map 并发读写问题源码分析
  13. 编程语言学习方法总结
  14. lisp ssget 浩辰_lisp程序--AutoCAD和浩辰GstarCAD.pdf
  15. js进行数学运算,加法,减法,乘法,除法
  16. 如何提问,才能让别人回答我们的问题呢?
  17. lstm需要优化的参数_通过Keras 构建基于 LSTM 模型的故事生成器
  18. 数据可视化新闻,不一样的新闻报道形式
  19. 用MATLAB程序控制伺服电机,使用MATLAB和Arduino开发板进行步进电机控制
  20. 【论文阅读】R3Det

热门文章

  1. Markdown基本语法(摘录)
  2. 面试必备 | 带你彻底搞懂 Python 生成器。
  3. 有线猫眼监控_如何安装有线监控摄像头系统
  4. linux中查看rpm包位置,linux中,查看某个命令是来自哪个RPM包或者是通过哪个RPM包安装的...
  5. marlin固件烧录教程_Marlin固件的步进电机控制代码解析
  6. windows平台使用Docker搭建分布式hadoop集群
  7. 1 常用邮箱SMTP/POP3地址及端口
  8. php对url转码,如何使用php url中文转码
  9. Matlab中_pkg.exe,pkg文件该如何打开?轻松打开pkg文件的方法
  10. python+appium+夜神模拟器APP自动化测试