一般情況下,在函數調用時形參從實參那里取得值,因此實參的個數應與形參相同。有時多次調用同一函數時用同樣的實參,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