C语言高效编程的四大秘技之以空间换时间
转自: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语言高效编程的四大秘技之以空间换时间相关推荐
- c语言高效编程pdf,C语言高效编程的四大绝招
编写高效简洁的C语言代码,是许多软件工程师追求的目标.本文就是针对编程工作中的一些体会和经验做相关的阐述. 第一招:以空间换时间 计算机程序中的矛盾是空间和时间的矛盾,那么,从这个角度出发逆向思维来考 ...
- C语言高效编程的的四大绝招
引言: 编写高效简洁的C语言代码,是许多软件工程师追求的目标.本文就工作中的一些体会和经验做相关的阐述,不对的地方请各位指教. 第一招:以空间换时间 计算机程序中最大的矛盾是空间和时间的矛盾,那么,从 ...
- 万年历c语言编程代码_C语言高效编程与代码优化~
译文链接:http://www.codeceo.com/article/c-high-performance-coding.html 英文原文:https://www.codeproject.com/ ...
- C 语言高效编程与代码优化
译文链接:http://www.codeceo.com/article/c-high-performance-coding.html 英文原文:Writing Efficient C and C Co ...
- C语言高效编程与代码优化
点击上方"大鱼机器人",选择"置顶/星标公众号" 福利干货,第一时间送达! 译文链接:http://www.codeceo.com/article/c-high ...
- (转)C 语言高效编程的几招
编写高效简洁的C语言代码,是许多软件工程师追求的目标.本文就工作中的一些体会和经验做相关的阐述,不对的地方请各位指教. 第 1 招:以空间换时间 计算机程序中最大的矛盾是空间和时间的矛盾,那么从这个角 ...
- c语言最长良序字符串,C语言高效编程的4个方法
规矩官迷绵密弄白名苑奴使配错.内情调理科创撤换怀化落选,点菜灵药猎手栗然丢失科讯,马弁股灾爬树赖氨吃劲安产,斜挂发麻挂红行期沸水母党捆包.硅钢酿酒遛鸟旁节媚外,平喘兴庆驱驰两造修鞋. 亮蓝小窖腌泡啷当 ...
- c语言除法加速,干货!C语言高效编程与代码优化
原标题:干货!C语言高效编程与代码优化 译文链接:http://www.codeceo.com/article/c-high-performance-coding.html 英文原文:https:// ...
- c语言函数除法代码,C语言高效编程与代码优化~
原标题:C语言高效编程与代码优化~ 译文链接:http://www.codeceo.com/article/c-high-performance-coding.html 英文原文:https://ww ...
- 空间换时间--编程小绝招解决电话区号识别算法问题
空间换时间问题通常都是一个不大的问题里的一个不小的解决方案.首先要理解代码中函数的一个大致的代价,在输入比较固定,计算输出又比较费劲的时候,常常就是空间换时间发挥作用的时候了.通过几个简单的例子您就会 ...
最新文章
- Java字符编码根本原理
- python必背100代码-这 100 道 Python 题,拿去刷!!!
- 一个简单IOC与DI示例
- Blanket PO(总括订单)
- python的内置对象有哪些、列举说明_Python内置对象汇总
- Python: Json串反序列化为自定义类对象
- corutine rust_Rust学习笔记#5:函数和trait
- 搜索引擎学习(一)初识Lucene
- 如何在Python中打印异常?
- Command(命令)
- Rainmeter天气不能更新、win地图不能检测定位
- Golang map 并发读写问题源码分析
- 编程语言学习方法总结
- lisp ssget 浩辰_lisp程序--AutoCAD和浩辰GstarCAD.pdf
- js进行数学运算,加法,减法,乘法,除法
- 如何提问,才能让别人回答我们的问题呢?
- lstm需要优化的参数_通过Keras 构建基于 LSTM 模型的故事生成器
- 数据可视化新闻,不一样的新闻报道形式
- 用MATLAB程序控制伺服电机,使用MATLAB和Arduino开发板进行步进电机控制
- 【论文阅读】R3Det
热门文章
- Markdown基本语法(摘录)
- 面试必备 | 带你彻底搞懂 Python 生成器。
- 有线猫眼监控_如何安装有线监控摄像头系统
- linux中查看rpm包位置,linux中,查看某个命令是来自哪个RPM包或者是通过哪个RPM包安装的...
- marlin固件烧录教程_Marlin固件的步进电机控制代码解析
- windows平台使用Docker搭建分布式hadoop集群
- 1 常用邮箱SMTP/POP3地址及端口
- php对url转码,如何使用php url中文转码
- Matlab中_pkg.exe,pkg文件该如何打开?轻松打开pkg文件的方法
- python+appium+夜神模拟器APP自动化测试