C++程序中有时需要调用C接口函数。实现混合编程,但是想让C++和C正常工作运行,只能告诉该语言的编译器,让当前的编译器兼用。那怎么做呢?先看看C++中调用C接口。
C++中调用C接口
首先先写一个.c和.h文件,然后C++中调用C接口。看看会发生什么情况?
test.c
#include <stdio.h>
#include "test.h"
void C_fun()
{
printf("C fun\n");
}
test.h
#ifndef __TEST_H__
#define __TEST_H__
extern void C_fun();
#endif
在调用C接口时,先编译.c函数
gcc -c test.c
编译成一个目标文件test.o,让C++编译器知道此函数接口是C提供的。接着调用C接口如下:
main.cpp
#include <iostream>
#include "test.h"
using namespace std;
int main(int argc,char **argv)
{
cout << "Prepare to call the C interface" << endl;
C_fun();
return 0;
}
编译结果:
编译结果很奇怪,明明定义了C_fun,但是为什么编译器说未定义呢?
揭开真相
C++中函数支持重载,而C并不支持。C++为了支持函数重载,在编译时,要对函数的名字进行一些处理,比如加入函数的返回类型等来加以区别;在C中,只是简单的函数名字而已。
C则把该函数编译成类似C_fun的符号,C++会把它编译成U_Z5C_funv, 看来改编的符号名是在函数名前加了一个前缀,如果没有参数就在后面加一个字母v,如果是int参数就加一个i,如果是char参数就加一个c,float参数就加一个f,double参数加一个d。
可以看出名字都不同,还怎么链接。所以编译器报错未定义的引用。
解决未定义问题
#ifndef __TEST_H__
#define __TEST_H__
#ifdef __cplusplus /*C++编译器包含的宏,例如用g++编译时,该宏就存在,则下面的语句extern "C"才会被执行*/
extern "C" {
#endif
void C_fun();
#ifdef __cplusplus
}
#endif
#endif
再接着编译:
extern “C” 在 C++编译器才能支持,C编译器不支持。如果你的C代码想要能够被C调用,也想被C++调用,那么别忘了extern “C”
扫二维码关注微信公众号,获取技术干货