如何區分C++中的inline和#define巨集
(1)什麼是行內函數?
行內函數是指那些定義在類體內的成員函式,即該函式的函式體放在類體內。
(2)為什麼要引入行內函數?
當然,引入行內函數的主要目的是:解決程式中函式呼叫的效率問題。
另外,前面我們講到了巨集,裡面有這麼一個例子:
#define ABS(x) ((x)>0? (x):-(x))
當++i出現時,巨集就會歪曲我們的意思,換句話說就是:巨集的定義很容易產生二意性。
(3)為什麼inline能取代巨集?
1、 inline 定義的類的行內函數,函式的程式碼被放入符號表中,在使用時直接進行替換,(像巨集一樣展開),沒有了呼叫的開銷,效率也很高。
2、 很明顯,類的行內函數也是一個真正的函式,編譯器在呼叫一個行內函數時,會首先檢查它的引數的型別,保證呼叫正確。然後進行一系列的相關檢查,就像對待任何一個真正的函式一樣。這樣就消除了它的隱患和侷限性。
3、 inline 可以作為某個類的成員函式,當然就可以在其中使用所在類的保護成員及私有成員。
(4)行內函數和巨集的區別?
行內函數和巨集的區別在於,巨集是由前處理器對巨集進行替代,而行內函數是通過編譯器控制來實現的。而且行內函數是真正的函式,只是在需要用到的時候,行內函數像巨集一樣的展開,所以取消了函式的引數壓棧,減少了呼叫的開銷。你可以象呼叫函式一樣來呼叫行內函數,而不必擔心會產生於處理巨集的一些問題。行內函數與帶引數的巨集定義進行下比較,它們的程式碼效率是一樣,但是內聯歡函式要優於巨集定義,因為行內函數遵循的型別和作用域規則,它與一般函式更相近,在一些編譯器中,一旦關上內聯擴充套件,將與一般函式一樣進行呼叫,比較方便。
(5)什麼時候用行內函數?
行內函數在C++類中,應用最廣的,應該是用來定義存取函式。我們定義的類中一般會把資料成員定義成私有的或者保護的,這樣,外界就不能直接讀寫我們類成員的資料了。對於私有或者保護成員的讀寫就必須使用成員介面函式來進行。如果我們把這些讀寫成員函式定義成行內函數的話,將會獲得比較好的效率。
Class A { Private:int nTest; Public:int readtest() { return nTest;} void settest(int I) { nTest=I; } }
(6)如何使用行內函數?
我們可以用inline來定義行內函數。
inline int A (int x) { return 2*x; }
不過,任何在類的說明部分定義的函式都會被自動的認為是行內函數。
(7)行內函數的優缺點?
我們可以把它作為一般的函式一樣呼叫,但是由於行內函數在需要的時候,會像巨集一樣展開,所以執行速度確比一般函式的執行速度要快。當然,行內函數也有一定的侷限性。就是函式中的執行程式碼不能太多了,如果,行內函數的函式體過大,一般的編譯器會放棄內聯方式,而採用普通的方式呼叫函式。(換句話說就是,你使用行內函數,只不過是向編譯器提出一個申請,編譯器可以拒絕你的申請)這樣,行內函數就和普通函式執行效率一樣了。
(8)如何禁止函式進行內聯?
如果使用VC++,可以使用/Ob命令列引數。當然,也可以在程式中使用 #pragma auto_inline達到相同的目的。
(9)注意事項:
1.在行內函數內不允許用迴圈語句和開關語句。
2.行內函數的定義必須出現在行內函數第一次被呼叫之前。
以上就是如何區分C++中的inline和#define巨集的詳細內容,更多關於C++ inline和#define巨集的區別的資料請關注我們其它相關文章!