C++函数重载
在C++中函数重载是一个非常简单的概念,但是这个知识点有很多细节和扩展需要掌握。接下来让我们来扒拉扒拉它。
什么是C++函数重载?
同一作用域下,函数名相同,但是函数参数的根数或者参数类型不同,那么这一组函数就称为函数重载。
如果参数类型使用const进行修饰,函数还能重载成功吗?
当使用const修饰函数参数时,函数重载是否生效取决于是顶层const还是底层const,简单来说就是如果函数参数是顶层const即参数本身是否是常量,对于编译器来说无法区别,所以**当参数是否是常量时,无法进行重载。**但是当const修饰的是某种类型的引用或者指针时,那么就可以实现函数重载。
如果函数重载不在同一作用域,重载是否还会生效?
这个是不会生效的。因为编译器在当前作用域下找不到对应参数的同名函数,所以会造成重载失败。
C语言中由函数重载吗?
C语言中是没有函数重载的。因为在编译时,函数产生的连接符号是根据函数名和参数类型个数决定的,而在C++中函数编译产生的连接符号是根据函数名和参数类型个数决定的,所以在C语言中只能找到一个函数,无法实现函数重载。
C语言和C++的编译结果不同,如何在C++项目中编译C语言代码呢?
这是无法直接调用的。因为C编译生成的符号与C++编译生成的符号对应不上,所以找不到对应的函数实现,把C函数的实现括在“extern C”中。
如何在C项目中调用C++函数代码?
不存在像C++调用C的写法,将C++的函数声明括上“extern C++”,而是继续使用“extern C”,将C++的函数实现括上“extern C”。
有没有一种办法让一段C语言代码既能在C编译器中编译,又能在C++编译器中编译?
只要是C++编译器就内置了_cplusplus这个宏名,所以当使用C++编译器时,将会将中间的代码作为C语言进行编译,而如果使用C语言编译器,编译器中没有对应的宏定义,所以代码上下的宏定义都是无效的,呈现给编译器的就是一段C语言代码。
#ifdef _cplusplus
extern "C" {
#endif
int sum(int a, int b) {
return a + b;
}
#ifdef _cplusplus
}
#endif
到这里函数重载大致就这么多,我还是建议大家在看的时候多看看细节,要“知其然”也要“知其所以然”,加油吧!