首页 > 编程知识 正文

js获取函数的参数值,重载函数使用缺省参数

时间:2023-05-03 22:24:16 阅读:221389 作者:264

C++函数参数的缺省值

有一些参数的值在每次函数调用时都相同,书写这样的语句会使人厌烦。C++语言采用参数的缺省值使书写变得简洁(在编译时,缺省值由编译器自动插入)。

    参数缺省值的使用规则:

【规则8-3-1】参数缺省值只能出现在函数的声明中,而不能出现在定义体中。

例如:

    void Foo(int x=0, int y=0); // 正确,缺省值出现在函数的声明中

 

    void Foo(int x=0, int y=0)      // 错误,缺省值出现在函数的定义体中

    {

    }

为什么会这样?我想是有两个原因:一是函数的实现(定义)本来就与参数是否有缺省值无关,所以没有必要让缺省值出现在函数的定义体中。二是参数的缺省值可能会改动,显然修改函数的声明比修改函数的定义要方便。

 

【规则8-3-2】如果函数有多个参数,参数只能从后向前挨个儿缺省,否则将导致函数调用语句怪模怪样。

正确的示例如下:

void Foo(int x, int y=0, int z=0);

错误的示例如下:

void Foo(int x=0, int y, int z=0); 

 

要注意,使用参数的缺省值并没有赋予函数新的功能,仅仅是使书写变得简洁一些。它可能会提高函数的易用性,但是也可能会降低函数的可理解性。所以我们只能适当地使用参数的缺省值,要防止使用不当产生负面效果。示例8-3-2中,不合理地使用参数的缺省值将导致重载函数output产生二义性。

 

#include <iostream.h>

void output( int x);

void output( int x, float y=0.0);

 

void output( int x)

{

    cout << " output int " << x << endl ;

}

 

void output( int x, float y)

{

    cout << " output int " << x << " and float " << y << endl ;

}

 

void main(void)

{

    int x=1;

    float y=0.5;

//  output(x);          // error! ambiguous call

    output(x,y);        // output int 1 and float 0.5

}

 

示例8-3-2  参数的缺省值将导致重载函数产生二义性

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。