0. gcc -o
gcc -o 的優化仍然是機械的,想當然的。只有做到深入理解計算機系統,加深對編程語言的理解,才能寫出最優化的代碼。
? gcc -o0 ⇒ 不提供任何優化;
? gcc -o1 ⇒ 最基本的優化,主要對代碼的分支、表達式、常量等進行優化,編譯器會在較短的時間下將代碼變得更加短小,這樣體積就會變得更小,會減少內存的占用率,在操作系統進行內存調度時就會更快。
? 但是事情沒有絕對的優點,當一個龐大的程序被拆碎細分的話,內存占用會大大增加,由于當今系統大多數都是多線程,就會出現卡頓和反應延遲。
? 大的項目代碼不適合 gcc -o1 優化;
? gcc -o2:是對 o1 的進階,在 o1 在基礎上會進行更嚴格的劃分,最重要的是加入了寄存器的實用;
1. volatile 關鍵字
volatile 關鍵字能夠阻止編譯器的過度優化,可以做到如下兩件事情:
? 阻止編譯器為了提高速度將一個變量緩存到寄存器而不寫回;
? 阻止編譯器調整操作 volatile 變量的指令順序;
2. register 關鍵字
將代碼放在寄存器的方式是使用 register 修飾變量,適用于頻繁調用的變量。
總結
以上就是本文關于C/C++ 編譯器優化介紹的全部內容,希望對大家有所幫助。歡迎各位參閱本站其他相關專題,有什么問題可以隨時給我們留言,小編會及時回復大家的。
新聞熱點
疑難解答
圖片精選