內聯函式和巨集

2021-08-30 00:14:37 字數 1369 閱讀 9162

第一部分:巨集

為什麼要使用巨集呢?

因為函式的呼叫必須要將程式執行的順序轉移到函式所存放在記憶體中的某個地 址,將函式的程式內容執行完後,再返回到轉去執行該函式前的地方。這種轉移操作要求在轉去執行前要儲存現場並記憶執行的位址,轉回後要恢復現場,並按原來 儲存位址繼續執行。因此,函式呼叫要有一定的時間和空間方面的開銷,於是將影響其效率。

而巨集只是在預處理的地方把**展開,不需要額外的空間和時間方面的開銷,所以呼叫乙個巨集比呼叫乙個函式更有效率。

但是巨集也有很多的不盡人意的地方。

1、巨集不能訪問物件的私有成員。

2、巨集的定義很容易產生二意性。

我們舉個例子:

#define square(x) (x*x)

我 們用乙個數字去呼叫它,square(5),這樣看上去沒有什麼錯誤,結果返回25,是正確的,但是如果我們用squre (5+5)去呼叫的話,我們期望的結果是100,而巨集的呼叫結果是(5+5*5+5),結果是35,這顯然不是我們要得到的結果。避免這些錯誤的方法,一 是給巨集的引數都加上括號。

#define square(x) ((x)*(x))

第二部分:內聯函式

從上面的闡述,可以看到巨集有一些難以避免的問題,怎麼解決呢?

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

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

宣告內聯函式看上去和普通函式非常相似:

void f(int i, char c);

當你定義乙個內聯函式時,在函式定義前加上 inline 關鍵字,並且將定義放入標頭檔案:

inline void f(int i, char c)

內聯函式必須是和函式體申明在一起,才有效。

像這樣的申明inline function(int i)是沒有效果的,編譯器只是把函式作為普通的函式申明,我們必須定義函式體。

inline int function(int i)

這樣我們才算定義了乙個內聯函式。我們可以把它作為一般的函式一樣呼叫。但是執行速度確比一般函式的執行速度要快。

當然,內聯函式也有一定的侷限性。就是函式中的執行**不能太多了,如果,內聯函式的函式體過大,一般的編譯器會放棄內聯方式,而採用普通的方式呼叫函式。這樣,內聯函式就和普通函式執行效率一樣了。

有上面的兩者的特性,我們可以用內聯函式完全取代預處理巨集。

析構函式也可以作為內聯函式使用

內聯函式和巨集

1.內聯函式 在c 中我們通常定義以下函式來求兩個整數的最大值 複製 如下 int max int a,int b 為這麼乙個小的操作定義乙個函式的好處有 閱讀和理解函式 max 的呼叫,要比讀一條等價的條件表示式並解釋它的含義要容易得多 如果需要做任何修改,修改函式要比找出並修改每一處等價表示式容...

內聯函式和巨集

內聯函式是為了提高程式執行速度的一種改進。當程式執行時,有時候需要重複呼叫乙個函式,但是因為重複呼叫這個函式,會不斷的造成函式呼叫,會不斷進棧出棧造成cpu的消耗。而內聯函式是在編譯時就將這個函式邊入進去,不用再進行位址的跳轉。但是不可避免的產生了一些 記憶體的消耗,所有有時候使用者在申請內聯時,內...

巨集 函式和內聯

先說巨集和函式的區別 1.巨集做的是簡單的字串替換 注意是字串的替換,不是其他型別引數的替換 而函式的引數的傳遞,引數是有資料型別的,可以是各種各樣的型別.2.巨集的引數替換是不經計算而直接處理的,而函式呼叫是將實參的值傳遞給形參,既然說是值,自然是計算得來的.3.巨集在編譯之前進行,即先用巨集體替...