最近需要在由纯c语言编写的代码中调用C++的动态库,在网上找了一些资料,现在总结下解决方法。
主要的思想就是将C++的动态库再封装一层,在这一层编写C语言的函数api,这API中使用C++动态库提供的类;
具体例子如下:
1,假如C++动态库包含如下代码:
//myclass.h
#ifndef _MYCLASS_H #define _MYCLASS_H class MyClass { public: void print(); }; #endif
//myclass.cc
#include#include "myclass.h" using namespace std; void MyClass::print() { cout << "MyClass::print() called" << endl; }
编译链接生成动态库:libmyclass.so
g++ myclass.cc -shared -o libmyclass.so -I./ -fPIC
2,封装libmyclass.so中类的接口,生成libmyfunc.so
//myfunc.h
#ifndef _MYFUNCTION_H #define _MYFUNCTION_H #ifdef _cplusplus extern "C" { #endif void myprint(); #ifdef _cplusplus } #endif #endif
//myfunc.c
#include "myclass.h" #ifndef _cplusplus #define _cplusplus #include "myfunc.h" #endif void myprint() { MyClass mc; mc.print(); }
编译链接生成动态库(C语言接口):
g++ myfunc.c -shared -o libmyfunc.so -L./ -lmyclass -fPIC -Xlinker -rpath=./
3,测试libmyfunc.so中提供的接口
//main.c
#include "myfunc.h" int main(int argc, char **argv) { myprint(); }
编译链接生成可执行代码:
gcc main.c -o main -lmyfunc -L./ -I. -Xlinker -rpath=./
执行main文件,输出如下:
MyClass::print() called
ok,大功搞成!!
注意事项:
1,注意myfunc.so必须是用g++来生成的,如果使用gcc,会不识别其中的类(这个解释不一定正确)
2,注意myfunc.h中_cpluscplus的用法,因为myfunc.h被main.c和myfunc.c两个文件用到,而extern仅被g++能够识别,
而不能够被gcc识别,解释的不一定对,还没有想清楚。。。。。
本文地址:http://www.yaronspace.cn/blog/index.php/archives/1046