先解释一下C和C++为什么不能直接互相调用:
C++支持函数重载,所以在编译的时候,函数名会发生变化。C语言不存在这个问题。那么在调用的时候,C++找的是变化后的函数名,而C语言找的是原始的函数名。所以两者不能直接调用。
举个例子:
如下代码,分别使用C和C++去编译,其库接口会发生变化:
#include <stdio.h>
int cpp_func(void)
{
printf("Hello from CPP!\n");
return 0;
}
C++编译生成的符号链接:
C语言编译生成的符号链接:
那么C和C++怎么实现互调了:
把需要互调的函数,使用extern C包起来。这样就可以了。extern C是告诉编译以C的方式去编译、调用。
注:C++的代码经过extern C包起来编译后,被其他C++代码调用时,其他代码需要extern C包一下调用的代码。不然会提示找不到对应的函数。
问题:别人提供给你的是C++未经过extern处理的代码库,你的代码是C代码,请问你怎么去调用。
解决:你自己创建一个cpp文件,调用他的代码库,让后将你的CPP文件使用extern处理。这样你的C代码调用你处理后的接口。
用到的测试相关的代码:
编译脚本:make.sh
#!/bin/bash
gcc test_c.c -o libtest_c.so -shared -fPIC
g++ test_cpp.cpp -o libtest_cpp.so -shared -fPIC
g++ src_cpp.cpp -o libsrc_cpp.so -shared -fPIC
gcc main_c.c -o main_c -L. -ltest_cpp
g++ main_cpp.cpp -o main_cpp -L. -ltest_c -ltest_cpp
LD_LIBRARY_PATH=. ./main_c
LD_LIBRARY_PATH=. ./main_cpp
c代码调用C++:main_c.c
#include <stdio.h>
#include "test_cpp.h"
int main()
{
printf("%s %s %d:\n", __FILE__, __func__, __LINE__);
cpp_func();
return 0;
}
c++代码调用C代码、C++extern代码:main_cpp.cpp
#include <stdio.h>
extern "C"
{
#include "test_c.h"
#include "test_cpp.h"
}
int main()
{
printf("%s %s %d:\n", __FILE__, __func__, __LINE__);
c_func();
cpp_func();
return 0;
}
C++代码:src_cpp.cpp(用于查看C++不经过extern处理编译出来的符号信息)
#include <stdio.h>
int cpp_func(void)
{
printf("Hello from CPP!\n");
return 0;
}
C库代码:test_c.c
#include <stdio.h>
int c_func(void)
{
printf("Hello from C!\n");
return 0;
}
C库头文件:test_c.h
#ifndef _TEST_C_H_
#define _TEST_C_H_
int c_func(void);
#endif /*_TEST_C_H_*/
C++库代码:test_cpp.cpp
#include <stdio.h>
#ifdef __cplusplus
extern "C" {
#endif
int cpp_func(void)
{
printf("Hello from CPP!\n");
return 0;
}
#ifdef __cplusplus
}
#endif
C++库头文件:test_cpp.h
#ifndef _TEST_CPP_H
#define _TEST_CPP_H
int cpp_func(void);
#endif /*_TEST_CPP_H*/