C inline和 define巨集的區別

2022-08-02 08:18:08 字數 1988 閱讀 3851

(1)什麼是內聯函式?

內聯函式是指那些定義在類體內的成員函式,即該函式的函式體放在類體內。

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

當然,引入內聯函式的主要目的是:解決程式中函式呼叫的效率問題。

另外,前面我們講到了巨集,裡面有這麼乙個例子:

#define abs(x) ((x)>0? (x):-(x))

當++i出現時,巨集就會歪曲我們的意思,換句話說就是:巨集的定義很容易產生二意性。

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

1、 inline 定義的類的內聯函式,函式的**被放入符號表中,在使用時直接進行

替換,(像巨集一樣展開),沒有了呼叫的開銷,效率也很高。 

2、 很明顯,類的內聯函式也是乙個真正的函式,編譯器在呼叫乙個內聯函式時,會

首先檢查它的引數的型別,保證呼叫正確。然後進行一系列的相關檢查,就像對待任何一

個真正的函式一樣。這樣就消除了它的隱患和侷限性。

3、 inline 可以作為某個類的成員函式,當然就可以在其中使用所在類的保護成員

及私有成員。

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

內聯函式和巨集的區別在於,巨集是由預處理器對巨集進行替代,而內聯函式是通過編譯器

控制來實現的。而且內聯函式是真正的函式,只是在需要用到的時候,內聯函式像巨集一樣

的展開,所以取消了函式的引數壓棧,減少了呼叫的開銷。你可以象呼叫函式一樣來呼叫

內聯函式,而不必擔心會產生於處理巨集的一些問題。

內聯函式與帶引數的巨集定義進行下比較,它們的**效率是一樣,但是內聯歡函式要

優於巨集定義,因為內聯函式遵循的型別和作用域規則,它與一般函式更相近,在一些編譯

器中,一旦關上內聯擴充套件,將與一般函式一樣進行呼叫,比較方便。

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

內聯函式在c++類中,應用最廣的,應該是用來定義訪問函式。我們定義的類中一般

會把資料成員定義成私有的或者保護的,這樣,外界就不能直接讀寫我們類成員的資料了

。對於私有或者保護成員的讀寫就必須使用成員介面函式來進行。如果我們把這些讀寫成

員函式定義成內聯函式的話,將會獲得比較好的效率。

class a

void settest(int i)

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

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

inline int a (int x)

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

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

我們可以把它作為一般的函式一樣呼叫,但是由於內聯函式在需要的時候,會像巨集一

樣展開,所以執行速度確比一般函式的執行速度要快。

當然,內聯函式也有一定的侷限性。就是函式中的執行**不能太多了,如果,內聯

函式的函式體過大,一般的編譯器會放棄內聯方式,而採用普通的方式呼叫函式。(換句話

說就是,你使用內聯函式,只不過是向編譯器提出乙個申請,編譯器可以拒絕你的申請)

這樣,內聯函式就和普通函式執行效率一樣了。

(8)如何禁止函式進行內聯?

如果使用vc++,可以使用/ob命令列引數。當然,也可以在程式中使用 #pragma auto_inline達到相同的目的。

(9)注意事項:

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

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

c inline和 define巨集的區別

1.為什麼要是用巨集定義 對比與一般的呼叫函式 因為呼叫巨集比呼叫函式更有效率,函式的呼叫必須要將程式的執行順序轉移到函式所存放的記憶體位址中,將函式程式內容執行完後,再返回到執行該函式前的地方,這種轉移操作要求執行前要儲存現場並記憶執行位址,轉回後要恢復現場,並按原來儲存的位址繼續執行,因此,函式...

c inline函式和巨集 函式呼叫

1 函式的呼叫必須將程式執行的順序轉移到存放函式所的位址,將函式的程式內容執行完成後,再次轉到執行該函式的地方,這種轉移操作要求執行前儲存現場,並記憶執行的位址。因此函式呼叫有一定的時間和空間開銷,影響效率。2 巨集只是在預處理的地方把 展開,不需要額外的位址和空間。所以巨集比函式呼叫更有效率。但是...

C inline 與 define 區別聯絡

1 inline與 define 內聯函式是 被插入到呼叫者 處的函式。如同 define 巨集,內聯函式通過避免被呼叫的開銷來提高執行效率,尤其是它能夠通過呼叫 過程化整合 被編譯器優化。2 區別 內聯函式在編譯時展開,而巨集是由預處理器對巨集進行展開 內聯函式會檢查引數型別,巨集定義不檢查函式引...