C++函数重载
- C++中函数名称可以重复,构成重载
- 必须在同一个作用域,且函数名称相同
- 引发重载的方式:函数的参数 个数不同,类型不同或者参数顺序不同
void func() {
cout << "无参数的func" << endl;
}
//函数重载
void func(int a) {
cout << "有参数的func" << endl;
}
void func(double a) {
}
void func(double a, int b) {
}
void func(int b, double a) {
}
- 返回值可以作为函数重载的条件吗?不可以,会出现二义性的问题。
- 当函数重载 碰到默认参数时候,要注意避免二义性的问题。(比如使用函数参数的数量进行重载,但数量多的使用了默认参数,此时出现二义性)
//当函数重载 碰到默认参数时候,要注意避免二义性的问题
//下列两个函数当面临调用func2(10)时,会出现二义性
void func2(int a, int b = 20) {
}
void func2(int a) {
}
- 引用的重载版本:因为传给引用的必须拥有实际的内存空间,加了const关键字修饰后,实际上上会开辟一块临时的空间,这时就可以接受没有空间的纯数字等,因此也引发了函数重载
//引用的重载版本
void func3(int& a) {//传给引用的必须拥有实际的内存空间,这个函数无法接受纯数字
cout << "没有加const" << endl;
}
void func3(const int& a) {//加了const关键字修饰后,实际上会开辟一块临时的空间,这是就可以接受没有空间的纯数字等,因此也引发了函数重载
cout << "加了const" << endl;
}
函数重载的实现原理
编译器的功劳,让自己内部能够识别出来,编译器内部会用不同的参数修饰不同的函数名,比如void func(),在编译器内部可能就是_func(),如果带参数,比如void func(int a),那可能就会是_func_int_()。总之编译器会根据函数重载的一些区别在内部通过修饰不同的函数名来区分。