一、什麼是內聯函式
在c語言中,如果一些函式被頻繁的呼叫,不斷地用函式入棧,即函式棧,則會造成棧空間或者棧記憶體的大量消耗,為了解決這個問題,特別的引入了inline關鍵字,表示為內聯函式。棧空間指的是函式內資料的記憶體空間,在乙個系統下,棧空間的資源是有限的,假如頻繁大量的使用就會因棧空間的不足而導致出錯,函式的死循壞遞迴呼叫的最終結果就是導致棧記憶體空間的枯竭。
像下面這個例子:
#include //函式定義為內聯函式
inline char *dbtest(int
a)int
main()
return0;
}
此例子就是內聯函式的標準用法,使用內聯函式帶來的好處就是,在每個for循壞內部任何呼叫dbtest(i)的地方都將會替換成(i % 2 > 0 ? "奇" : "偶"),因此,通過這樣子的替換就可以避免了頻繁呼叫函式對棧記憶體重複開闢所帶來的消耗。
二、內聯函式的程式設計風格
1、關鍵字inline必須與函式的定義體放在一起,才能使函式成為內聯函式,僅僅將inline放在函式宣告前面不起作用
例如,下面風格的函式fun將不能成為內聯函式:
inline void fun(int x, int y); //inline僅僅與函式宣告放在一起
void fun(int x, int
y)
如下風格的函式fun則成為內聯函式:
void fun(int x, inty);inline
void fun(int x, int y) //
inline與函式的定義放在一起
2、關鍵字inline的使用是有所限制的
inline只適合函式體內**比較簡單的函式使用,不能包含複雜的結構控制語句,例如while、switch,並且內聯函式本身不能是直接遞迴函式(函式內部呼叫自己的函式)。
三、慎用內聯
內聯能提高函式的執行效率,但是不能把所有的函式都定義為內聯函式,內聯是以**膨脹(複製)為代價的,僅僅是省去了函式呼叫的開銷,從而提高函式的執行效率。如果執行函式體內**的時間,相比於函式呼叫的開銷較大,那麼執行的效率收穫會很少,另一方面,每一處內聯函式的呼叫都會複製**,從而使程式的總**量增加,消耗更多的記憶體空間。
下面情況不適合使用內聯函式:
(1)如果函式體內的**較長,使用內聯將導致記憶體消耗代價較高;
(2)如果函式體內出現循壞,那麼執行函式體內的**將要比函式呼叫的開銷更大。
四、static和inline聯合使用
static是靜態修飾符,由其關鍵字修飾的變數會儲存到全域性資料區,對於普通的區域性變數或者全域性變數,都是由系統自動分配記憶體的,並且當變數離開作用域的時候釋放掉,而使用static關鍵字來修飾,只有當程式結束時候才會釋放掉,使用static inline修飾時,函式僅在檔案內部可見,不會汙染命名空間,另外,函式在執行過程中也會分配記憶體空間,但是由於static的存在,就和修飾變數類似,它只會開闢一塊記憶體空間。
C 中的inline關鍵字
from here 在c c 中,為了解決一些頻繁呼叫的小函式大量消耗棧空間 棧記憶體 的問題,特別的引入了inline修飾符,表示為內聯函式。棧空間就是指放置程式的區域性資料 也就是函式內資料 的記憶體空間。在系統下,棧空間是有限的,假如頻繁大量的使用就會造成因棧空間不足而導致程式出錯的問題,如,...
inline關鍵字的用法詳解
在c c 中,為了解決一些頻繁呼叫的小函式大量消耗棧空間 棧記憶體 的問題,特別的引入了inline修飾符,表示為內聯函式。棧空間就是指放置程式的區域性資料 也就是函式內資料 的記憶體空間。在系統下,棧空間是有限的,假如頻繁大量的使用就會造成因棧空間不足而導致程式出錯的問題,如,函式的死迴圈遞迴呼叫...
C 關鍵字之inline
一般在呼叫函式時會產生該函式的棧幀結構,在棧幀結構中儲存關於該函式的引數 變數等臨時資料 另外還要儲存現場,函式返回後還要恢復現場。這些都要花費一些時間。如果有的函式需要頻繁使用,則在反覆呼叫的過程中會有很大的時間開銷,降低程式執行效率。c 提供了一種提高效率的方法,即在編譯時將所呼叫的函式的 直接...