內聯函數是指那些定義在類體內的成員函數,即該函數的函數體放在類體內。
內聯函數從源代碼層看,有函數的結構,而在編譯后,卻不具備函數的性質。內聯函數不是在調用時發生控制轉移,而是在編譯時將函數體嵌入在每一個調用處。編譯時,類似宏替換,使用函數體替換調用處的函數名。一般在代碼中用inline修飾,但是能否形成內聯函數,需要看編譯器對該函數定義的具體處理。
內聯函數是使用inline關鍵字聲明的函數,也成內嵌函數,它主要的作用是解決程序的運行效率。
使用內聯函數的時候要注意:
1.遞歸函數不能定義為內聯函數
2.內聯函數一般適合於不存在while和switch等復雜的結構且只有1~5條語句的小函數上,否則編譯系統將該函數視為普通函數。
3.內聯函數只能先定義后使用,否則編譯系統也會把它認為是普通函數。
4.對內聯函數不能進行異常的接口聲明。
為什么inline能取代宏?
1、 inline 定義的類的內聯函數,函數的代碼被放入符號表中,在使用時直接進行替換,(像宏一樣展開),沒有了調用的開銷,效率也很高。
2、 很明顯,類的內聯函數也是一個真正的函數,編譯器在調用一個內聯函數時,會首先檢查它的參數的類型,保證調用正確。然后進行一系列的相關檢查,就像對待任何一個真正的函數一樣。這樣就消除了它的隱患和局限性。
3、 inline 可以作為某個類的成員函數,當然就可以在其中使用所在類的保護成員及私有成員。
內聯函數和宏的區別?
內聯函數和宏的區別在於,宏是由預處理器對宏進行替代,而內聯函數是通過編譯器控制來實現的。而且內聯函數是真正的函數,只是在需要用到的時候,內聯函數像宏一樣的展開,所以取消了函數的參數壓棧,減少了調用的開銷。你可以象調用函數一樣來調用內聯函數,而不必擔心會產生於處理宏的一些問題。內聯函數與帶參數的宏定義進行下比較,它們的代碼效率是一樣,但是內聯歡函數要優於宏定義,因為內聯函數遵循的類型和作用域規則,它與一般函數更相近,在一些編譯器中,一旦關上內聯擴展,將與一般函數一樣進行調用,比較方便。
如何使用內聯函數?
我們可以用inline來定義內聯函數。
inline int A (int x) { return 2*x; }
不過,任何在類的說明部分定義的函數都會被自動的認為是內聯函數。
內聯函數的優缺點?
我們可以把它作為一般的函數一樣調用,但是由於內聯函數在需要的時候,會像宏一樣展開,所以執行速度確比一般函數的執行速度要快。當然,內聯函數也有一定的局限性。就是函數中的執行代碼不能太多了,如果,內聯函數的函數體過大,一般的編譯器會放棄內聯方式,而采用普通的方式調用函數。(換句話說就是,你使用內聯函數,只不過是向編譯器提出一個申請,編譯器可以拒絕你的申請)這樣,內聯函數就和普通函數執行效率一樣了。