c++的简单函数重载
函数重载概念
- 函数重载:是函数的一种特殊情况,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++在编译的时候是如何对函数名修饰的?或者采取了什么算法来修改函数名的?我们来看一看。
可以看出c++中,编译器实际在底层使用的不是Add名字,而是被重新修饰过的一个比较复杂的名字,被重新修饰后的名字中包含了:函数的名字以及参数类型。这就是为什么函数重载中几个同名函数要求其参数列表不同的原因。只要参数列表不同,编译器在编译时通过对函数名字进行重新修饰,将参数类型包含在最终的名字中,就可保证名字在底层的全局唯一性。
- 那再看看这两个函数可以形成重载吗?
void TestFunc(int a = 10)
{
cout<<"void TestFunc(int)"<<endl;
}
void TestFunc(int a)
{
cout<<"void TestFunc(int)"<<endl;
}
- 这两个函数不能形成重载,带默认的函数不能形成重载,因为你调用它的时候,编译器不知道你要调用那个函数。
有时候在C++工程中可能需要将某些函数按照 C 的风格来编译,在函数前加 extern “C”,意思是告诉编译器,将该函数按照C语言规则来编译。
extern "C" int Add(int left, int right);
int main()
{
Add(1,2);
return 0;
}