(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.內聯函式的定義必須出現在內聯函式第一次被呼叫之前。
內聯函式與巨集定義
用內聯取代巨集 1.內聯可除錯 2.可進行型別安全檢查或自動型別轉換 3.可訪問成員變數。另外,定義在類宣告中的成員函式自動轉化為內聯函式。內聯函式與巨集定義 在c中,常用預處理語句 define來代替乙個函式定義。例如 define max a,b a b a b 該語句使得程式中每個出現max ...
內聯函式與巨集定義
1 內聯函式取消了引數的壓棧,減少呼叫的開銷 2 內聯函式宣告必須和定義一起,如果只有宣告,編譯器只會將它看做普通函式的宣告,如果宣告的時候使用inline,定義在其他地方也用inline,那麼它是內聯還是普通函式 普通函式。查彙編 內聯函式與普通函式一樣?3 c 類中定義的函式都預設是內聯函式,無...
巨集定義與內聯函式
1 巨集定義的規則和使用解析 1 巨集定義的解析規則就是 在預處理階段由預處理器進行替換,這個替換是原封不動的替換。2 巨集定義替換會遞迴進行,直到替換出來的值本身不再是乙個巨集為止。3 乙個正確的巨集定義式子本身分為3部分 第一部分是 dedine 第二部分是巨集名 剩下的所有為第三部分。4 巨集...