C程式的效率優化建議

2021-09-10 06:25:46 字數 2148 閱讀 8164

程式設計時要經常注意**的效率。在保證軟體系統的正確性、穩定性、可讀性及可測性的前提下,提高**效率。

**效率分為全域性效率、區域性效率、時間效率及空間效率。全域性效率是站在整個系統的角度上的系統效率;區域性效率是站在模組或函式角度上的效率;時間效率是程式處理輸入任務所需的時間長短;空間效率是程式所需記憶體空間,如機器**空間大小、資料空間大小、棧空間大小等。

區域性效率應為全域性效率服務,不能因為提高區域性效率而對全域性效率造成影響。

通過對系統資料結構的劃分與組織的改進,以及對程式演算法的優化來提高空間效率。

示例:如下記錄學生學習成績的結構不合理。

typedef struct student_score_stru

student_score;

因為每位學生都有多科學習成績是不一樣的,故如上結構將占用較大空間。應如下改進(分為兩個結構),總的存貯空間將變小,操作也變得更方便。

typedef struct student_stru

student;

typedef struct student_score_stru

student_score;

迴圈體內工作量最小化。應仔細考慮迴圈體內的語句是否可以放在迴圈體之外,使迴圈體內工作量最小,從而提高程式的時間效率。

示例:如下**效率不高。

for (ind = 0; ind < max_add_number; ind++)

語句「back_sum = sum;」完全可以放在for語句之後,如下。

for (ind = 0; ind < max_add_number; ind++)

back_sum = sum; /* backup sum */

仔細分析有關演算法,並進行優化。仔細考查、分析系統及模組處理輸入(如事務、訊息等)的方式,並加以改進。對模組中函式的劃分及組織方式進行分析、優化,改進模組中函式的組織結構,提高程式效率。軟體系統的效率主要與演算法、處理任務方式、系統功能及函式結構有很大關係,僅在**上下功夫一般不能解決根本問題。

程式設計時,要隨時留心**效率;優化**時,要考慮周全。不應花過多的時間拼命地提高呼叫不很頻繁的函式**效率。對**優化可提高效率,但若考慮不周很有可能引起嚴重後果。

要仔細地構造或直接用彙編編寫呼叫頻繁或效能要求極高的函式。只有對編譯系統產生機器碼的方式以及硬體系統較為熟悉時,才可使用彙編嵌入方式。嵌入彙編可提高時間及空間效率,但也存在一定風險。

在保證程式質量的前提下,通過壓縮**量、去掉不必要**以及減少不必要的區域性和全域性變數,來提高空間效率。這種方式對提高空間效率可起到一定作用,但往往不能解決根本問題。

在多重迴圈中,應將最忙的迴圈放在最內層。以減少cpu切入迴圈層的次數。

示例:如下**效率不高。

for (row = 0; row < 100; row++)

}可以改為如下方式,以提高效率。

for (col = 0; col < 5; col++)

}

儘量減少迴圈巢狀層次。避免迴圈體內含判斷語句,應將迴圈語句置於判斷語句的**塊之中。目的是減少判斷次數。迴圈體中的判斷語句是否可以移到迴圈體外,要視程式的具體情況而言,一般情況,與迴圈變數無關的判斷語句可以移到迴圈體外,而有關的則不可以。

示例:如下**效率稍低。

for (ind = 0; ind < max_rect_number; ind++)

else }

因為判斷語句與迴圈變數無關,故可如下改進,以減少判斷次數。

if (data_type == rect_area)

} else }

盡量用乘法或其它方法代替除法,特別是浮點運算中的除法。因為浮點運算除法要占用較多cpu資源。

示例:如下表示式運算可能要佔較多cpu資源。

#define pai 3.1416

radius = circle_length / (2 * pai);

應如下把浮點除法改為浮點乘法。

#define pai_reciprocal (1 / 3.1416 ) // 編譯器編譯時,將生成具體浮點數

radius = circle_length * pai_reciprocal / 2;

不要一味追求緊湊的**。因為緊湊的**並不代表高效的機器碼。

優化C 程式編譯效率的實

發帖人 flytothespace 時 間 詳細資訊 1 自定義程式的入口 2 合併區段 3 不用調malloc,free等函式 3 不用cout來輸出,cin來輸入 4 如果呼叫了很多庫函式如memset,stycpy等等 的話,請匯入msvcrt.lib,不然編譯器會在程式裡面 匯入靜態庫,這樣...

優化C 程式編譯效率的例項

1 自定義程式的入口 2 合併區段 3 不用調malloc,free等函式 3 不用cout來輸出,cin來輸入 4 如果呼叫了很多庫函式如memset,stycpy等等 的話,請匯入msvcrt.lib,不然編譯器會在程式裡面 匯入靜態庫,這樣的話程式就會大很多。5 window 程式設計不用mf...

c c 程式優化幾個建議

第一 記住,寫完後一定要做一下系統優化,無論上面是否這樣要求,但是這點很重要,是一種態度,當然優化可以借助各種工具如ibm和intel系列的優化工具,一般80 的時間被20 的 所占用。第二 如果你所在公司,對程式效能優化不重視,那麼就請跳槽吧。第三 要知道你所用編譯器是怎麼去優化多維陣列訪問的,如...