转自:https://blog.csdn.net/malloc_luo/article/details/104437926
用Keil编写C、C++混编程序碰到了这个问题
#ifdef __cplusplus
extern "C"{
#endif /*__cplusplus*/
//overload
void foo(int ,int );
void foo(float );
#ifdef __cplusplus
}
#endif /*__cplusplus*/
编译之后报错:
more than one instance overload function “foo” has C linkage
意思是说foo存在C链接。
问题的关键在extern "C"
C++保留了一部分过程式语言的特点,因而它可以定义不属于任何类的全局变量和函数。但是,C++毕竟是一种面向对象的程序设计语言,为了支持函数的重载,C++对全局函数的处理方式与C有明显的不同。
extern “C”的主要作用就是为了能够正确实现C++代码调用其他C语言代码。加上extern “C”后,会指示编译器这部分代码按C语言的进行编译,而不是C++的。由于C++支持函数重载,因此编译器编译函数的过程中会将函数的参数类型也加到编译后的代码中,而不仅仅是函数名;而C语言并不支持函数重载,因此编译C语言代码的函数时不会带上函数的参数类型,一般之包括函数名。
比如说你用C 开发了一个DLL 库,为了能够让C ++语言也能够调用你的DLL输出(Export)的函数,你需要用extern “C”来强制编译器不要修改你的函数名。
————————————————
版权声明:本文为CSDN博主「一蓑烟雨1989」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/wangshubo1989/article/details/50784124
C++支持函数重载而C不支持函数重载。这里加上extern “C” 表示让这段代码按C编译,自然会报错。教训是不要乱加extern “C” 除非确有必要,比如有C的lib、dll或者中断服务函数的声明。
————————————————
版权声明:本文为CSDN博主「HawaiiHello」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/malloc_luo/article/details/104437926