標籤:
1. 內嵌函式的定義
內嵌函式在定義時與普通函數基本一致,只是在函數值的類型前加”inline“關鍵字,定義方法:
inline 函數值的類型 函數名 (形參及其類型列表)
{ 函數體 }
本人自學,教材可能有點老,有問題的話求大家指正!!!謝謝!!!
2. 內嵌函式與普通函數的區別和聯絡
- 定義內嵌函式時增加了 inline 關鍵字;
- 兩者在程式中調用的方式和方法相同;
- 當程式調用一個內嵌函式時,將該函數的代碼直接插入到調用點執行。所以,調用過程中不存在程式流程的跳轉和返回問題;普通函數反之;
- 從調用機理看,內嵌函式可以加快程式碼的執行速度和效率並減少調用開銷,但是增加了程式碼。
3. 內嵌函式的限制
- 內嵌函式的函數體內不能含有複雜的結構控制語句,如果含有,則編譯器將該函數視該函數同普通函數那樣產生函數調用代碼;
- 遞迴函式不能被用做內嵌函式;
- 內嵌函式中不能說明數組;
- 內嵌函式一般適合於只有1~5行語句的小函數。
例題:定義一個求兩個整數中較小值的函數min(),要求定義成內嵌函式,然後在main函數中進行調用。
1 #include<iostream> 2 using namespace std; 3 4 inline int min(int a, int b){ return a<b?a:b;} 5 6 int main() 7 { 8 int a=2; 9 int b=7;10 int c=4;11 cout << "a,b:" << min(a,b) << endl;12 cout << "b,c:" << min(b,c) << endl;13 cout << "c,a:" << min(c,a) << endl;14 return 0;15 }16 17 //菜鳥,求大家批評指教,代碼編寫習慣和規範等等!!!謝謝!!!
運行結果如下:
a,b:2
b,c:4
c,a:2
本人自學,教材可能有點老,有問題的話求大家指正!!!謝謝!!!
C++內嵌函式