c語言空間換時間優化代碼的技巧方法

計算機程序中最大的矛盾是空間和時間的矛盾,那麼,從這個角度出發逆向思維來考慮程序的效率問題,我們就有了解決問題的第1招--以空間換時間。以下是小編爲大家搜索整理的C語言空間換時間優化代碼的方法技巧,希望能給大家帶來幫助!更多精彩內容請及時關注我們考試網!

c語言空間換時間優化代碼的技巧方法

比如說字符串的賦值:

方法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,則需要預存許多字符串,雖然佔用了大量的內存,但是獲得了程序執行的高效率。

如果系統的實時性要求很高,內存還有一些,那我推薦你使用該招數。