a一级爱做片免费观看欧美,久久国产一区二区,日本一二三区免费,久草视频手机在线观看

新聞中心

EEPW首頁 > 嵌入式系統 > 設計應用 > 內聯函數詳解

內聯函數詳解

作者: 時間:2010-05-24 來源:網絡 收藏

什么是內聯性和外聯函數

本文引用地址:http://www.j9360.com/article/257961.htm

類的成員函數可以分為和外聯函數。是指那些定義在類體內的成員函數,即該函數的函數體放在類體內。而說明在類體內,定義在類體外的成員函數叫外聯函數。外聯函數的函數體在類的實現部分。

在調用時不是像一般的函數那樣要轉去執行被調用函數的函數體,執行完成后再轉回調用函數中,執行其后語句,而是在調用函數處用內聯函數體的代碼來替換,這樣將會節省調用開銷,提高運行速度。

內聯函數與前面講過的帶參數的宏定義進行一下比較,它們的代碼效率是一樣的,但是內聯函數要優于宏定義,因為內聯函數遵循函數的類型和作用域規則,它與一般函數更相近,在一些編譯器中,一旦關上內聯擴展,將與一般函數一樣進行調用,調試比較方便。

外聯函數變成內聯函數的方法很簡單,只要在函數頭前面加上關鍵字就可以了。


#include iostream>
using namespace std;
class A
{
public:
A(int x, int y) //內聯函數
{
X=x;Y=y;
}
int a() //內聯函數
{
return X;
}
int b() //內聯函數
{
return Y;
}
int c();
int d();
private:
int X,Y;
};
//定義內聯函數
int A::c()
{
return a()+b();
}
inline int A::d()
{
return c();
}

void main()
{
A m(3,5);
int I=m.d();
coutd()return:Iendl;
}


輸出結果:

d()return:8

說明:類A中,直接定義了3個內聯函數,又使用inline定義了2個內聯函數。


引入內聯函數的意義

函數是一種更高級的抽象。它的引入使得編程者只關心函數的功能和使用方法,而不必關心函數功能的具體實現;函數的引入可以減少程序的目標代碼,實現程序代碼和數據的共享。但是,函數調用也會帶來降低效率的問題,因為調用函數實際上將程序執行順序轉移到函數所存放在內存中某個地址,將函數的程序內容執行完后,再返回到轉去執行該函數前的地方。這種轉移操作要求在轉去前要保護現場并記憶執行的地址,轉回后先要恢復現場,并按原來保存地址繼續執行。因此,函數調用要有一定的時間和空間方面的開銷,于是將影響其效率。特別是對于一些函數體代碼不是很大,但又頻繁地被調用的函數來講,解決其效率問題更為重要。引入內聯函數實際上就是為了解決這一問題。

在程序編譯時,編譯器將程序中出現的內聯函數的調用表達式用內聯函數的函數體來進行替換。顯然,這種做法不會產生轉去轉回的問題,但是由于在編譯時將函數體中的代碼被替代到程序中,因此會增加目標程序代碼量,進而增加空間開銷,而在時間代銷上不象函數調用時那么大,可見它是以目標代碼的增加為代價來換取時間的節省。

在程序中,調用其函數時,該函數在編譯時被替代,而不是像一般函數那樣是在運行時被調用。


使用內聯函數應注意的事項

內聯函數具有一般函數的特性,它與一般函數所不同之處只在于函數調用的處理。一般函數進行調用時,要將程序執行權轉到被調用函數中,然后再返回到調用它的函數中;而內聯函數在調用時,是將調用表達式用內聯函數體來替換。在使用內聯函數時,應注意如下幾點:

1.在內聯函數內不允許用循環語句和開關語句。

如果內聯函數有這些語句,則編譯將該函數視同普通函數那樣產生函數調用代碼,遞歸函數(自己調用自己的函數)是不能被用來做內聯函數的。內聯函數只適合于只有1~5行的小函數。對一個含有許多語句的大函數,函數調用和返回的開銷相對來說微不足道,所以也沒有必要用內聯函數實現。

2.內聯函數的定義必須出現在內聯函數第一次被調用之前。

3.本欄目講到的類結構中所有在類說明內部定義的函數是內聯函數。



關鍵詞: 內聯函數 性能 inline

評論


相關推薦

技術專區

關閉