C++函數參數取默許值的深刻詳解。本站提示廣大學習愛好者:(C++函數參數取默許值的深刻詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是C++函數參數取默許值的深刻詳解正文
普通情形下,在函數挪用時形參從實參那邊獲得值,是以實參的個數應與形參雷同。有時屢次挪用統一函數時用異樣的實參,C++供給簡略的處置方法,給形參一個默許值,如許形參就不用必定要從實參取值了。若有一函數聲明
float area(float r=6.5);
指定r的默許值為6.5,假如在挪用此函數時,確認r的值為6.5,則可以不用給出實參的值,如
area( ); //相當於area(6.5);
假如不想使形參取此默許值,則經由過程實參另行給出。如area(7.5); //形參獲得的值為7.5,而不是6.5
這類辦法比擬靈巧,可以簡化編程,進步運轉效力。
假如有多個形參,可使每一個形參有一個默許值,也能夠只對一部門形參指定默許值,另外一部門形參不指定默許值。若有一個求圓柱體體積的函數,形參h代表圓柱體的高,r為圓柱體半徑。函數原型以下:
float volume(float h,float r=12.5); //只對形參r指定默許值12.5
函數挪用可以采取以下情勢:
volume(45.6); //相當於volume(45.6,12.5)
volume(34.2,10.4) //h的值為34.2,r的值為10.4
實介入形參的聯合是從左至右次序停止的。是以指定默許值的參數必需放在形參表列中的最右端,不然失足。例如:
void f1(float a,int b=0,int c,char d=′a′); //不准確
void f2(float a,int c,int b=0, char d=′a′); //准確
假如挪用下面的f2函數,可以采用上面的情勢:
f2(3.5, 5, 3, ′x′) //形參的值全體從實參獲得
f2(3.5, 5, 3) //最初一個形參的值取默許值′a′
f2(3.5, 5) //最初兩個形參的值取默許值,b=0,d=′a′
可以看到,在挪用有默許參數的函數時,實參的個數可以與形參的個數分歧,實參未給定的,從形參的默許值獲得值。應用這一特征,可使函數的應用加倍靈巧。例如例4.7求2個數或3個數中的最年夜數。也能夠不消重載函數,而改用帶有默許參數的函數。
例4.8 求2個或3個正整數中的最年夜數,用帶有默許參數的函數完成。
#include <iostream>
using namespace std;
int main( )
{int max(int a, int b, int c=0);//函數聲明,形參c有默許值
int a,b,c;
cin>>a>>b>>c;
cout<<″max(a,b,c)=″<<max(a,b,c)<<endl; //輸入3個數中的最年夜者
cout<<″max(a,b)=″<<max(a,b)<<endl; //輸入2個數中的最年夜者
return 0;
}
int max(int a,int b,int c) //函數界說
{if(b>a) a=b;
if(c>a) a=c;
return a;
}
運轉情形以下:
14 -56 135↙
max(a,b,c)=135