C++入门——函数重载与缺省
先说说什么是缺省
大家生活中都知道什么关于缺省这个词的例子吗?
肯定是一头雾水,没事我举一个例子,给大家解释一下。
假如小菜是一个舔狗,他天天跟女神买早餐、嘘寒问暖。可是女神还是天天不为所动,如果当女神老了年纪大了,想找个人结婚可是身边没有可用之人,那他就会想到小菜,反之有合适对象,就不会再去搭理小菜了。
这是小菜就是可有可无的存在,在了不会影响,但是要用的时候可以顶一下。
那我在用代码写一个例子
void TestFunc(int a = 0)
{
cout<<a<<endl;
}
int main()
{
TestFunc(); // 没有传参时,使用参数的默认值
TestFunc(10); // 传参时,使用指定的实参
}
如果什么都没输入则是输出0,输入数字便会显示输入的数字。
全缺省与半缺省
缺省还分为半缺省和全缺省。
void TestFunc(int a = 0)
{
cout<<a<<endl;
}
int main()
{
TestFunc(); // 没有传参时,使用参数的默认值
TestFunc(10); // 传参时,使用指定的实参
}
全缺省,就和上面的例子一样,给的所有的参数都给了缺省值。
半缺省则是只给了一部分。
void TestFunc(int a, int b = 10, int c = 20)
{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
}
或者
void TestFunc(int a, int b, int c = 20)
{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
}
但是不可以像下面一样.
void TestFunc(int a, int b = 10, int c )
{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
}
void TestFunc(int a= 20, int b = 10, int c )
{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
}
只能从左往右缺省,不可以从右往左缺省,也不能中间缺省,要连续缺省。
缺省参数不能在函数声明和定义中同时出现
如:
//a.h
void TestFunc(int a = 10);
// a.c
void TestFunc(int a = 20)
{}
注意:如果生命与定义位置同时出现,恰巧两个位置提供的值不同,那编译器就无法确定到底该用那
个缺省值。
所以只要在一个地方给出缺省值就好。
什么是函数重载
自然语言中,一个词可以有多重含义,人们可以通过上下文来判断该词真实的含义,即该词被重载了。
比如:以前有一个笑话,国有两个体育项目大家根本不用看,也不用担心。一个是乒乓球,一个是男足。前
者是“谁也赢不了!”,后者是“谁也赢不了!”
函数重载:是函数的一种特殊情况,C++允许在同一作用域中声明几个功能类似的同名函数,这些同名函数的
形参列表(参数个数 或 类型 或 顺序)必须不同,常用来处理实现功能类似数据类型不同的问题。
只是参数个数 或 类型 或 顺序不同这个概念太重要了。
int Add(int left, int right)
{
return left+right;
}
double Add(double left, double right)
{
return left+right;
}
long Add(long left, long right)
{
return left+right;
}
int main()
{
Add(10, 20);
Add(10.0, 20.0);
Add(10L, 20L);
return 0;
}
和返回类型无关,返回类型不同不构成重载。
这两个函数构成重载吗?
short Add(short left, short right)
{
return left+right;
}
int Add(short left, short right)
{
return left+right;
}
显然不构成,因为参数类型,个数,顺序都一样,会编译错误的。
通过这里就理解了C语言没办法支持重载,因为同名函数没办法区分。而C++是通过函数修饰规则来区分,只要参数不同,修饰出来的名字就不一样,就支持了重载。
C不支持重载,C++支持重载,有兴趣可以去研究一下,这里大家就记住就可以了。