CCS工程的头文件中添加extern "C" { }语句的原因是,由于C++支持函数重载,一个函数的名字可能有几个,在编译到汇编的时候,这些函数可能被重新命名(不是简单的在开头添加下划线'_'),这样C语言或汇编在链接由C++实现的函数时就会找不到具体位置。
C语言的规则是添加"_"前缀表示函数在汇编中的名称,例如main函数在汇编中为_main,但是C++不行,C++有重载。比如有以下函数:
void fun(const char* msg)
{
printf("%s\n", msg);
}
void fun(int val)
{
printf("%d\n",val);
}
int main()
{
fun("hello");
fun(123);
return 0;
}
函数fun有2个,如果将fun简单用"_"前缀的话,就会出现2个不同的函数,但是名字都是_fun。C++的处理方法是重命名,第一个可能被命名为_fun_const_char_XCC1,第二个可能为_fun_int_SXX,名字中除了参数信息,可能还有一些随机字串(这样是为了避免冲突)。如果将void fun(int val)函数导出为C语言接口,就要在声明的时候添加extern "C"修饰。如下所示:
#ifndef XXX_H
#define XXX_H
#ifdef __cplusplus
extern "C" {
#endif
//各种声明
#ifdef __cplusplus
}
#endif
#endif
C语言的规则是添加"_"前缀表示函数在汇编中的名称,例如main函数在汇编中为_main,但是C++不行,C++有重载。比如有以下函数:
void fun(const char* msg)
{
printf("%s\n", msg);
}
void fun(int val)
{
printf("%d\n",val);
}
int main()
{
fun("hello");
fun(123);
return 0;
}
函数fun有2个,如果将fun简单用"_"前缀的话,就会出现2个不同的函数,但是名字都是_fun。C++的处理方法是重命名,第一个可能被命名为_fun_const_char_XCC1,第二个可能为_fun_int_SXX,名字中除了参数信息,可能还有一些随机字串(这样是为了避免冲突)。如果将void fun(int val)函数导出为C语言接口,就要在声明的时候添加extern "C"修饰。如下所示:
#ifndef XXX_H
#define XXX_H
#ifdef __cplusplus
extern "C" {
#endif
//各种声明
#ifdef __cplusplus
}
#endif
#endif