C语言高效编程的几招小技巧
这篇文章主要介绍了 C 语言高效编程的几招小技巧 ,本文讲解了以空间换时间、用数学方
法解决问题以及使用位操作等编辑技巧 , 并给出若干方法和代码实例 , 需要的朋友可以参考
下
引言:
编写高效简洁的 C 语言代码,是许多软件工程师追求的目标。本文就工作中的一些
体会和经验做相关的阐述,不对的地方请各位指教。
第 1 招:以空间换时间
计算机程序中最大的矛盾是空间和时间的矛盾,那么,从这个角度出发逆向思维来
考虑程序的效率问题,我们就有了解决问题的第 1 招 —— 以空间换时间。
例如:字符串的赋值。
方法 A ,通常的办法:
代码如下 :
#define LEN 32
char string1 [LEN];
memset (string1,0,LEN);
strcpy (string1, “isThisa example!! )”;
方法 B:
代码如下 :
const char string2[LEN] = “Thisis a example! ”;
char * cp;
cp = string2 ;
( 使用的时候可以直接用指针来操作。 )
从上面的例子可以看出, A 和 B 的效率是不能比的。在同样的存储空间下, B 直接
使用指针就可以操作了,而 A 需要调用两个字符函数才能完成。 B 的缺点在于灵 活性没
有 A 好。在需要频繁更改一个字符串内容的时候, A 具有更好的灵活性;如果采用方法
B,则需要预存许多字符串,虽然占用了大量的内存,但是获得了程序 执行的高效率。
如果系统的实时性要求很高,内存还有一些,那我推荐你使用该招数。
该招数的变招 ——使用宏函数而不是函数。举例如下:
方法 C :
代码如下 :
#define bwMCDR2_ADDRESS 4
#define bsMCDR2_ADDRESS 17
int 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);
函数和宏函数的区别就在于,宏函数占用了大量的空间,而函数占用了时间。大家
要知道的是,函数调用是要使用系统的栈来保存数据的,如果编译器里有栈检查