詳解C++中的內(nèi)聯(lián)函數(shù)和函數(shù)重載
內(nèi)聯(lián)函數(shù)(內(nèi)嵌函數(shù),內(nèi)置函數(shù))
調(diào)用函數(shù)時需要一定的時間和空間的開銷。C++提供一種提高效率的方法,即在編譯時將函數(shù)調(diào)用處用函數(shù)體替換,類似于C語言中的宏展開。這種在函數(shù)調(diào)用處直接嵌入函數(shù)體的函數(shù)稱為內(nèi)聯(lián)函數(shù)(inline function),又稱內(nèi)嵌函數(shù)或內(nèi)嵌函數(shù)。
指定內(nèi)聯(lián)函數(shù)的方法很簡單,只需要在定義函數(shù)時增加 inline 關(guān)鍵字。
注意:是在函數(shù)定義時增加 inline 關(guān)鍵字,而不是在函數(shù)聲明時。在函數(shù)聲明時增加 inline 關(guān)鍵雖然沒有錯誤,但是也沒有任何效果
inline 關(guān)鍵字放在函數(shù)聲明處不會起作用:
inline void swap(int &a, int &b); void swap(int &a, int &b) { int temp = a; a = b; b = temp; } inline 關(guān)鍵字應(yīng)該與函數(shù)體放在一起: void swap(int &a, int &b); inline void swap(int &a, int &b) { int temp = a; a = b; b = temp; }
采用內(nèi)聯(lián)函數(shù)可以有效避免函數(shù)調(diào)用的開銷,程序執(zhí)行效率更高。使用內(nèi)聯(lián)函數(shù)的缺點就是,如果被聲明為內(nèi)聯(lián)函數(shù)的函數(shù)體非常大,則編譯器編譯后程序的可執(zhí)行碼將會變得很大。
另外,如果函數(shù)體內(nèi)出現(xiàn)循環(huán)或者其它復(fù)雜的控制結(jié)構(gòu)的時候,這個時候處理這些復(fù)雜控制結(jié)構(gòu)所花費的時間遠大于函數(shù)調(diào)用所花的時間,因此如果將這類函數(shù)聲明為內(nèi)聯(lián)函數(shù)意義不大,反而會使得編譯后可執(zhí)行代碼變長。
通常在程序設(shè)計過程中,我們會將一些頻繁被調(diào)用的短小函數(shù)聲明為內(nèi)聯(lián)函數(shù)。
應(yīng)當(dāng)說明:對函數(shù)作inline聲明,只是程序員對編譯系統(tǒng)提出的一個建議,也就是說它是建議性的,而不是指令性的。并非一經(jīng)指定為inline,編譯系統(tǒng)就必須這樣做。編譯系統(tǒng)會根據(jù)具體情況決定是否這樣做。
一個完整的示例:
#include <iostream> using namespace std; int max(int, int, int); //函數(shù)聲明,左端也可以加inline int main( ) { int i=10, j=20, k=30, m; m = max(i, j, k); cout<<"max="<<m<<endl; return 0; } inline int max(int a, int b, int c) //定義max為內(nèi)聯(lián)函數(shù) { if(b>a) a=b; if(c>a) a=c; return a; }
運行結(jié)果:
max=30
由于在定義函數(shù)時指定它為內(nèi)置函數(shù),因此編譯系統(tǒng)在遇到函數(shù)調(diào)用“max(i, j, k)”時,就用max函數(shù)體的代碼代替“max(i,j, k)”,同時將實參代替形參。這樣,程序第6行 “m=max(i, j, k);”就被置換成:
if (j>i) i=j; if(k>i) i=k; m=i;
函數(shù)重載
在編程時,有時我們要實現(xiàn)的是同一類的功能,只是有些細節(jié)不同。例如希望從3個數(shù)中找出其中的最大者,而每次求最大數(shù)時數(shù)據(jù)的類型不同,可能是3個整數(shù)、3個雙精度數(shù)或3個長整數(shù)。程序設(shè)計者往往會分別設(shè)計出3個不同名的函數(shù),其函數(shù)原型為:
int max1(int a, int b, int c); //求3個整數(shù)中的最大者 double max2(double a, double b, double c); //求3個雙精度數(shù)中最大者 long max3(long a, long b, long c); //求3個長整數(shù)中的最大者
C++允許用同一函數(shù)名定義多個函數(shù),這些函數(shù)的參數(shù)個數(shù)和參數(shù)類型不同。這就是函數(shù)的重載(function overloading)。即對一個函數(shù)名重新賦予它新的含義,使一個函數(shù)名可以多用。
對上面求最大數(shù)的問題可以編寫如下的C++程序。
【例】求3個數(shù)中最大的數(shù)(分別考慮整數(shù)、雙精度數(shù)、長整數(shù)的情況)。
#include <iostream> using namespace std; int main( ) { int max(int a,int b,int c); //函數(shù)聲明 double max(double a,double b,double c); //函數(shù)聲明 long max(long a,long b,long c);//函數(shù)聲明 int i1,i2,i3,i; cin>>i1>>i2>>i3; //輸入3個整數(shù) i=max(i1,i2,i3); //求3個整數(shù)中的最大者 cout<<"i_max="<<i<<endl; double d1,d2,d3,d; cin>>d1>>d2>>d3; //輸入3個雙精度數(shù) d=max(d1,d2,d3); //求3個雙精度數(shù)中的最大者 cout<<"d_max="<<d<<endl; long g1,g2,g3,g; cin>>g1>>g2>>g3; //輸入3個長整數(shù) g=max(g1,g2,g3); //求3個長整數(shù)中的最大者 cout<<"g_max="<<g<<endl; } int max(int a,int b,int c) //定義求3個整數(shù)中的最大者的函數(shù) { if(b>a) a=b; if(c>a) a=c; return a; } double max(double a,double b,double c)//定義求3個雙精度數(shù)中的最大者的函數(shù) { if(b>a) a=b; if(c>a) a=c; return a; } long max(long a,long b,long c) //定義求3個長整數(shù)中的最大者的函數(shù) { if(b>a) a=b; if(c>a) a=c; return a; }
運行情況如下:
185-76567↙ (輸入3個整數(shù)) 56.87 90.23 -3214.78↙ (輸入3個實數(shù)) 67854 -912456 673456↙ (輸入3個長整數(shù)) i_max=567 (輸出3個整數(shù)的最大值) d_max=90.23 (輸出3個雙精度數(shù)的最大值) g_max=673456 (輸出3個長整數(shù)的最大值)
上例3個max函數(shù)的函數(shù)體是相同的。
其實重載函數(shù)并不要求函數(shù)體相同;除了允許參數(shù)類型不同以外,還允許參數(shù)的個數(shù)不同。
【例】編寫一個程序,用來求兩個整數(shù)或3個整數(shù)中的最大數(shù)。如果輸入兩個整數(shù),程序就輸出這兩個整數(shù)中的最大數(shù),如果輸入3個整數(shù),程序就輸出這3個整數(shù)中的最大數(shù)。
#include <iostream> using namespace std; int main( ) { int max(int a,int b,int c); //函數(shù)聲明 int max(int a,int b); //函數(shù)聲明 int a=8,b=-12,c=27; cout<<"max(a,b,c)="<<max(a,b,c)<<endl;//輸出3個整數(shù)中的最大者 cout<<"max(a,b)="<<max(a,b)<<endl; //輸出兩個整數(shù)中的最大者 } int max(int a,int b,int c)//此max函數(shù)的作用是求3個整數(shù)中的最大者 { if(b>a) a=b; if(c>a) a=c; return a; } int max(int a,int b)//此max函數(shù)的作用是求兩個整數(shù)中的最大者 { if(a>b) return a; else return b; }
運行情況如下:
max(a, b, c)=27 max(a, b)=8
兩次調(diào)用max函數(shù)的參數(shù)個數(shù)不同,系統(tǒng)就根據(jù)參數(shù)的個數(shù)找到與之匹配的函數(shù)并調(diào)用它。
參數(shù)的個數(shù)和類型可以都不同。但不能只有函數(shù)的類型不同而參數(shù)的個數(shù)和類型相同。例如:
int f(int); //函數(shù)返回值為整型 long f(int); //函數(shù)返回值為長整型 void f(int); //函數(shù)無返回值
在函數(shù)調(diào)用時都是同一形式,如“f(10)”。編譯系統(tǒng)無法判別應(yīng)該調(diào)用哪一個函數(shù)。重載函數(shù)的參數(shù)個數(shù)、參數(shù)類型或參數(shù)順序3者中必須至少有一種不同,函數(shù)返回值類型可以相同也可以不同。
在使用重載函數(shù)時,同名函數(shù)的功能應(yīng)當(dāng)相同或相近,不要用同一函數(shù)名去實現(xiàn)完全不相干的功能,雖然程序也能運行,但可讀性不好,使人莫名其妙。
相關(guān)文章
C++?中如何結(jié)束?while?(cin>>str)?的輸入
這篇文章主要介紹了C++?中如何結(jié)束?while?(cin>>str)?的輸入,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07一篇文章教你如何用C語言實現(xiàn)strcpy和strlen
這篇文章主要為大家介紹了C語言實現(xiàn)strcpy和strlen的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-01-01C++ Qt實現(xiàn)瀏覽器網(wǎng)頁內(nèi)嵌的音視頻播放器
這篇文章主要為大家詳細介紹了如何利用C++ Qt實現(xiàn)瀏覽器網(wǎng)頁內(nèi)嵌的音視頻播放器,并支持軟硬解碼,支持音頻,支持錄像截圖,支持多路播放等,感興趣的可以了解下2024-01-01