- 函数重载的条件
- 在同一作用域
- 相同的名称
- 不同的参数 个数,类型,顺序
- 注意事项:
- 返回值不能走位函数重载的条件
- 引用中,避免函数重载的二义性
- 默认参数中,避免函数重载的二义性
上代码:
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
using namespace std;
//(1)函数重载的条件:
//1.必须在同一作用域下
//2.函数的名称必须相同
//3.函数的参数 个数、类型、顺序 不同时 才可以进行函数重载
void func() //原函数
{
cout << "func()被调用" << endl;
}
void func(int a) //个数不同
{
cout << "func(int a)被调用" << endl;
}
void func(double a) //类型不同
{
cout << "func(double a)被调用" << endl;
}
void func(int a, double b) //个数不同
{
cout << "func(int a,double b)被调用" << endl;
}
void func(double a, int b) //顺序不同
{
cout << "func(double a,int b)被调用" << endl;
}
//(2)注意函数的返回值不同 不能进行函数重载
//(3)函数重载中的二义性
// 1.引用中 函数重载只有下面2中方式,当出现 void func2(int a)时,也就出现了二义性。
void func2(int &a)
{
cout << "func(int &a)被调用" << endl;
}
void func2(const int &a)
{
cout << "func(const int &a)被调用" << endl;
}
//void func2(int a) 当此函数出现时,也就出现了二义性
//{
// cout << "func2(int a)被调用" << endl;
//}
// 2.默认参数中,函数重载的二义性,因为默认参数可以省略,当被省略时,有可能出现重载函数和原函数的实参个数相同
void func3(int a)
{
}
void func3(int a, int b = 10) //当 调用func3(10)时,便出现了二义性,因为2个函数都可以用这句语句调用
{
}
int main()
{
system("pause");
return EXIT_SUCCESS;
}