1. 程式人生 > >行內函數與巨集的區別

行內函數與巨集的區別

 行內函數是程式碼被插入到呼叫者程式碼處的函式。如同 #define 巨集,行內函數通過避免被呼叫的開銷來提高執行效率,尤其是它能夠通過呼叫(“過程化整合”)被編譯器優化。  

    內 聯函式和巨集很類似,而區別在於,巨集是由前處理器對巨集進行替代,而行內函數是通過編譯器控制來實現的。而且行內函數是真正的函式,只是在需要用到的時候,內 聯函式像巨集一樣的展開,所以取消了函式的引數壓棧,減少了呼叫的開銷。你可以象呼叫函式一樣來呼叫行內函數,而不必擔心會產生於處理巨集的一些問題。

行內函數和巨集都是在程式出現的地方展開;
行內函數不是通過函式呼叫實現的, 是在呼叫該函式的程式處將它展開(在編譯期間完成的);
不同的是:行內函數可以在編譯期間完成諸如型別檢測,語句是否正確等編譯功能;巨集就不具有這樣的功能,而且巨集展開的時間和行內函數也是不同的(在執行期間展開)
  
    宣告行內函數看上去和普通函式非常相似:  
    void f(int i, char c);  
    
      
    當你定義一個行內函數時,在函式定義前加上 inline 關鍵字,並且將定義放入標頭檔案:  
    inline  
     void f(int i, char c)  
     {  
     // ...  
     }  
    
      
    任何在類的說明部分定義的函式都會被自動的認為是行內函數。  
    行內函數必須是和函式體申明在一起,才有效。像這樣的申明Inline Tablefunction(int I)是沒有效果的,編譯器只是把函式作為普通的函式申明,我們必須定義函式體。  
    Inline tablefunction(int I) {return I*I};  
    
    
    這樣我們才算定義了一個行內函數。我們可以把它作為一般的函式一樣呼叫。但是執行速度確比一般函式的執行速度要快。
    我們也可以將定義在類的外部的函式定義為行內函數,比如:
    Class TableClass{  
     Private:  
      Int I,j;  
     Public:  
      Int add() { return I+j;};  
      Inline int dec() { return I-j;}  
      Int GetNum();  
    }  
    inline int tableclass::GetNum(){  
    return I;  
    }  
    
    
    上面申明的三個函式都是行內函數。在C++中,在類的內部定義了函式體的函式,被預設為是行內函數。而不管你是否有inline關鍵字。
    內 聯函式在C++類中,應用最廣的,應該是用來定義存取函式。我們定義的類中一般會把資料成員定義成私有的或者保護的,這樣,外界就不能直接讀寫我們類成員 的資料了。對於私有或者保護成員的讀寫就必須使用成員介面函式來進行。如果我們把這些讀寫成員函式定義成行內函數的話,將會獲得比較好的效率。
    Class sample{  
     Private:  
      Int nTest;  
     Public:  
      Int readtest(){ return nTest;}  
     Void settest(int I) {nTest=I;}  
    }  
    
    
    當然,行內函數也有一定的侷限性。就是函式中的執行程式碼不能太多了,如果,行內函數的函式體過大,一般的編譯器會放棄內聯方式,而採用普通的方式呼叫函式。這樣,行內函數就和普通函式執行效率一樣了。