計算機程序中最大的矛盾是空間和時間的矛盾,那麼,從這個角度出發逆向思維來考慮程序的效率問題,我們就有了解決問題的第1招--以空間換時間。以下是小編爲大家搜索整理的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,則需要預存許多字符串,雖然佔用了大量的內存,但是獲得了程序執行的高效率。
如果系統的實時性要求很高,內存還有一些,那我推薦你使用該招數。