这是因为c和c++混编带来的问题。
1,问题根源:c++是支持类和名字空间,函数重载等高级技巧的。以函数重载为例:
int Add(int a, int b)
int Add(int a, int b, int c)
这意味着不同的函数有同样的名字(你写的,都叫Add),但是同样的名字会带来混淆,所以使用了一种叫“名字毁坏”的技术,不同的编译器有不同的毁坏规则,只要能实现区分就好。
所以,经过c++编译器的处理,你的Add名字已经面目全非,比如我这里叫:
错误 LNK2019 无法解析的外部符号 "int __fastcall Add(int,int)" (?Add@@YIHHH@Z),函数 _main 中引用了该符号。
到这,都没什么,只不过名字变了一下,只要编译器能处理正确就好。
但是,重点来了,你放了一个c文件进去,c语言,是不支持这些高级玩意儿的,名字也不会毁坏,这样,一个毁坏一个还是原名,得,两下对不上了。
2,解决办法
解决办法也是模式化的,当你声明的变量或者函数在c文件实现的时候,在h文件里声明的时候,用这样的结构包含起来,无论有多少个函数,都可以放在一起。
#ifdef __cplusplus
extern "C" {
#endif
int Add(int, int);
//其他声明
#ifdef __cplusplus
}
#endif
再编译就不会出现Link错误了。
头文件全文如下:
#pragma once
#ifdef __cplusplus
extern "C" {
#endif
int Add(int, int);
#ifdef __cplusplus
}
#endif