目录
2、函数重载条件:同一作用域参数个数不同,参数类型不同,参数顺序不同
1、函数重载:同一个函数名在不同场景下可以具有不同的含义
2、函数重载条件:同一作用域参数个数不同,参数类型不同,参数顺序不同
代码示例:
void func() {
cout << "无参的func" << endl;
}
void func(int a) {
cout << "一个参数的func" << endl;
}
void func(int a,int b) {
cout << "两个参数的func" << endl;
}
void func(char a) {
cout << "char类型的func" << endl;
}
void func(double a) {
cout << "double类型的func" << endl;
}
void test() {
func();
func(10);
func(10, 10);
func(20.2);
func('a');
}
int main() {
test();
}
运行结果:
注意:
1、函数的返回值类型不能作为函数重载的依据
2、 函数重载和默认参数一起使用,需要格外注意二义性问题的产生
此时调用myfuc(20)函数,编译器可以与一个参数的myfunc匹配,也可以与具有默认参数的两个参数myfunc匹配,这时候系统就不知道调用那个了,就产生了二义性问题。
3、函数重载的原理:
编译器为了实现函数重载,也是默认为我们做了一些幕后的工作,编译器用不同的参数类型来修饰不同的函数名,比如 void func;编译器可能会将函数名修饰成func,当编译器碰到void func(intx)编译器能将丽数名修饰为funcint;当编译器碰到void func(int x ,char c)编译器可能会将函数名修饰为funcintchar 我这里使用"可能”这个字眼是因为编译器如何修饰重载的函数名称并没有一个统一的标准,所以不同的编译器可能会产生不同的内部名。
void func(){}void func(int x){}
void func(int x,char y){}
以下三个函数在 linux下生成的编译之后的函数名为:
Z4funcv //v 代表void,无参数
Z4funci //i 代表参数为int类型
Z4funcic //i 代表第一个参数为 int 类型,第二个参数为 char 类型