一、在C&C++中
一、inline 關鍵字用來定義一個類的內聯函數,引入它的主要原因是用它替代C中表達式形式的宏定義。
表達式形式的宏定義一例:
#define ExpressionName(Var1,Var2) ((Var1)+(Var2))*((Var1)-(Var2))為什麼要取代這種形式呢,且聽我道來:
1. 首先談一下在C中使用這種形式宏定義的原因,C語言是一個效率很高的語言,這種宏定義在形式及使用上像一個函數,但它使用預處
理器實現,沒有了參數壓棧,代碼生成 等一系列的操作,因此,效率很高,這是它在C中被使用的一個主要原因。
2. 這種宏定義在形式上類似於一個函數,但在使用它時,僅僅只是做預處理器符號表中的簡單替換,因此它不能進行參數有效性的檢測
,也就不能享受C++編譯器嚴格類型檢查的好處,另外它的返回值也不能被強制轉換為可轉換的合適的類型,這樣,它的使用就存在著一系列的
隱患和局限性。
3. 在C++中引入了類及類的訪問控制,這樣,如果一個操作或者說一個表達式涉及到類的保護成員或私有成員,你就不可能使用這種宏定
義來實現(因為無法將this指針放在合適的位置)。
4. inline 推出的目的,也正是為了取代這種表達式形式的宏定義,它消除了它的缺點,同時又很好地繼承了它的優點。
二、為什麼inline能很好地取代預定義呢?
對應於上面的1-3點,闡述如下:
1. inline 定義的類的內聯函數,函數的代碼被放入符號表中,在使用時直接進行替換,(像宏一樣展開),沒有了調用的開銷,效率也
很高。
2. 很明顯,類的內聯函數也是一個真正的函數,編譯器在調用一個內聯函數時,會首先檢查它的參數的類型,保證調用正確。然後進行
一系列的相關檢查,就像對待任何一個真正的函數一樣。這樣就消除了它的隱患和局限性。
3. inline 可以作為某個類的成員函數,當然就可以在其中使用所在類的保護成員及私有成員。在何時使用inline函數:首先,你可以使
用inline函數完全取代表達式形式的宏定義。另外要注意,內聯函數一般只會用在函數內容非常簡單的時候,這是因為,內聯函數的代碼會在
任何調用它的地方展開,如果函數太復雜,代碼膨脹帶來的惡果很可能會大於效率的提高帶來的益處。內聯函數最重要的使用地方是用於類的
存取函數。
三、如何使用類的inline函數:
簡單提一下inline 的使用吧:
1.在類中定義這種函數:
代碼如下:
class ClassName
{
.....
....
inlline GetWidth(){return m_lPicWidth;} // 如果在類中直接定義,需用inline修飾
....
....
};
2.在類中聲明,在類外定義:
代碼如下:
class ClassName
{
.....
....
GetWidth(); // 如果在類外直接定義,可以不使用inline修飾
....
....
};