1.函数重载
作用:函数名字一样,提高了复用性。
函数重载的条件:
相同:
1.同一个作用域下。
2.函数名称相同。
不同:1.函数参数类型不同
1.void func(int a)
2.void func(double b)
2. 函数参数个数不同
1.void func(int a)
2.void func(int a,int b)`
3.顺序不同
void func(double a,int b)
void func(int a,double b)
易错点:
函数的返回值不能作为重载的条件,因为编译器无法重载仅按返回值类型区分的函数。
void func(){}
int func(){} //无法构成重载,会报错
2.函数重载的注意事项。
(1)引用作为重载的条件时。
//先说结论,可以
#include <iostream>
using namespace std;
//函数重载,一定是引用时才行(加&),不加&的情况就没有加不加const这一说。第一次就犯的这错误。
void func(double &b) {
cout << "func(double b)" << endl;
}
void func(const double &b) {
cout << "func(const double b)" << endl;
}
int main()
{ //先是无const
double a = 1.0;
func(a);
//再是有const
func(1.0);
}

(2)函数重载碰到默认参数时。
先上结论:不可以。 因为我们也知道,默认参数可有可无,我要写上那个默认参数还能分辨出来,但是那我主函数中如果不写这个默认参数的话我调用哪个函数,这时候就产生了二义性。
void func(int a,int b=10){}
void func(int a){}
int main(){
func(1,2); //这个可以分辨调用哪个函数
func(1)//这个就不行,因为在编译器看来调用哪个都行,这就产生了二义性。
本文聚焦C++函数重载,介绍其作用是提高函数复用性。阐述函数重载条件,需在同一作用域且函数名相同,参数类型不同,强调返回值不能作为重载条件。还提及函数重载注意事项,如引用作重载条件、重载碰到默认参数会产生二义性。
1214

被折叠的 条评论
为什么被折叠?



