C 內聯函式

2021-06-16 22:00:37 字數 1378 閱讀 4152

(1)什麼是內聯函式?

內聯函式就是小型函式,犧牲空間來節省函式呼叫的開銷,一般用作比較小的函式,即函式內部沒有迴圈、開關語句等。內聯函式被發明出來就是為了取代c中的巨集,因為巨集是單純的替換而沒有型別檢查所以經常出毛病,

(2)為什麼要引入內聯函式?

當然,引入內聯函式的主要目的是:解決程式中函式呼叫的效率問題。另外,前面我們講到了巨集,裡面有這麼乙個例子:

#define max(a, b) (a) > (b) ? (a) : (b)

如果你在**中這樣寫:int a = 5, b = 10;

// int max = max(++a, b); // a自增了兩次

// int max = max(++a, b+10); // a自增了一次

(3)為什麼inline能取代巨集?

1、inline 定義的類的內聯函式,函式的**被放入符號表中,在使用時直接進行替換,(像巨集一樣展開),沒有了呼叫的開銷,效率也很高。

2、 很明顯,類的內聯函式也是乙個真正的函式,編譯器在呼叫乙個內聯函式時,會首先檢查它的引數的型別,保證呼叫正確。然後進行一系列的相關檢查,就像對待任何乙個真正的函式一樣。這樣就消除了它的隱患和侷限性。

(4)內聯函式和巨集的區別?

內聯函式和巨集的區別在於,巨集是由預處理器對巨集進行替代,而內聯函式是通過編譯器控制來實現的。而且內聯函式是真正的函式,只是在需要用到的時候,內聯函式像巨集一樣的展開,所以取消了函式的引數壓棧,減少了呼叫的開銷。你可以象呼叫函式一樣來呼叫內聯函式,而不必擔心會產生於處理巨集的一些問題。內聯函式與帶引數的巨集定義進行下比較,它們的**效率是一樣,但是內聯歡函式要優於巨集定義,因為內聯函式遵循的型別和作用域規則,它與一般函式更相近,在一些編譯器中,一旦關上內聯擴充套件,將與一般函式一樣進行呼叫,比較方便。

(5)什麼時候用內聯函式?

內聯擴充套件是用來消除

函式呼叫

時的時間開銷。它通常用於頻繁執行的函式。 乙個小記憶體空間的函式非常受益。

(6)如何使用內聯函式?

我們可以用inline來定義內聯函式。

inline int a (int x)

不過,任何在類的說明部分定義的函式都會被自動的認為是內聯函式。

(7)內聯函式的優缺點?

我們可以把它作為一般的函式一樣呼叫,但是由於內聯函式在需要的時候,會像巨集一樣展開,所以執行速度確比一般函式的執行速度要快。當然,內聯函式也有一定的侷限性。就是函式中的執行**不能太多了,如果,內聯函式的函式體過大,一般的編譯器會放棄內聯方式,而採用普通的方式呼叫函式。(換句話說就是,你使用內聯函式,只不過是向編譯器提出乙個申請,編譯器可以拒絕你的申請)這樣,內聯函式就和普通函式執行效率一樣了。

注意事項:

1.在內聯函式內不允許用迴圈語句和開關語句。

2.內聯函式的定義必須出現在內聯函式第一次被呼叫之前。

C 內聯函式

1 什麼是內聯函式?2 為什麼要引入內聯函式?3 為什麼inline能取代巨集?4 內聯函式和巨集的區別?5 什麼時候用內聯函式?6 如何使用內聯函式?7 內聯函式的優缺點?8 如何禁止函式進行內聯?9 注意事項 1 什麼是內聯函式?內聯函式是指那些定義在類體內的成員函式,即該函式的函式體放在類體內...

c 內聯函式

1 什麼是內聯函式?內聯函式是指那些定義在類體內的成員函式,即該函式的函式體放在類體內。2 為什麼要引入內聯函式?當然,引入內聯函式的主要目的是 解決程式中函式呼叫的效率問題。另外,前面我們講到了巨集,裡面有這麼乙個例子 define abs x x 0?x x 當 i出現時,巨集就會歪曲我們的意思...

C 內聯函式

2008 08 27 22 33 06 分類 c vc c 舉報 字型大小訂閱 巨集 就是使用乙個字串來代替乙個表示式 或函式呼叫 編譯之前,預處理器會使用這個巨集字串所代表的表示式 或函式呼叫 來替換所有出現的巨集字串,這樣的話,用巨集表示的函式呼叫 就不用另外開闢函式棧,不用保護和恢復函式呼叫現...