| 導購 | 订阅 | 在线投稿
分享
 
 
 

C++ 內聯函數

來源:互聯網  2008-06-01 01:54:30  評論

引入內聯函數的目的是爲了解決程序中函數調用的效率問題。

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

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

內聯函數的定義方法

定義內聯函數的方法很簡單,只要在函數定義的頭前加上要害字inline即可。內聯函數的定義方法與一般函數一樣。如:

inline int add_int (int x, int y, int z)

{

return x+y+z;

}

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

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

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

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

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

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

  引入內聯函數的目的是爲了解決程序中函數調用的效率問題。   函數是一種更高級的抽象。它的引入使得編程者只關心函數的功能和使用方法,而不必關心函數功能的具體實現;函數的引入可以減少程序的目標代碼,實現程序代碼和數據的共享。但是,函數調用也會帶來降低效率的問題,因爲調用函數實際上將程序執行順序轉移到函數所存放在內存中某個地址,將函數的程序內容執行完後,再返回到轉去執行該函數前的地方。這種轉移操作要求在轉去前要保護現場並記憶執行的地址,轉回後先要恢複現場,並按原來保存地址繼續執行。因此,函數調用要有一定的時間和空間方面的開銷,于是將影響其效率。非凡是對于一些函數體代碼不是很大,但又頻繁地被調用的函數來講,解決其效率問題更爲重要。引入內聯函數實際上就是爲了解決這一問題。   在程序編譯時,編譯器將程序中出現的內聯函數的調用表達式用內聯函數的函數體來進行替換。顯然,這種做法不會産生轉去轉回的問題,但是由于在編譯時將函數休中的代碼被替代到程序中,因此會增加目標程序代碼量,進而增加空間開銷,而在時間代銷上不象函數調用時那麽大,可見它是以目標代碼的增加爲代價來換取時間的節省。   內聯函數的定義方法   定義內聯函數的方法很簡單,只要在函數定義的頭前加上要害字inline即可。內聯函數的定義方法與一般函數一樣。如: inline int add_int (int x, int y, int z) { return x+y+z; }   在程序中,調用其函數時,該函數在編譯時被替代,而不是像一般函數那樣是在運行時被調用。   使用內聯函數應注重的事項   內聯函數具有一般函數的特性,它與一般函數所不同之處公在于函數調用的處理。一般函數進行調用時,要將程序執行權轉到被調用函數中,然後再返回到調用它的函數中;而內聯函數在調用時,是將調用表達式用內聯函數體來替換。在使用內聯函數時,應注重如下幾點:   1.在內聯函數內不答應用循環語句和開關語句。   2.內聯函數的定義必須出現在內聯函數第一次被調用之前。   3.本欄目講到的類結構中所有在類說明內部定義的函數是內聯函數。
󰈣󰈤
王朝萬家燈火計劃
期待原創作者加盟
 
 
 
>>返回首頁<<
 
 
 
 
 熱帖排行
 
 
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有