C调用C++函数库,一般不能直接调用,需要将C++库转换成C接口输出,方可以使用C调用,看下面的例子:
文件add.cpp
- //code in add.cpp
-
#include "add.h"
-
int sample::add(int a, int b)
-
{
-
cout<<"sample::add() is called!\n";
-
return (a+b);
-
}
文件add.h
- //code in add.h
-
#include <iostream>
-
-
using namespace std;
-
class sample
-
{
-
public:
-
int add(int a, int b);
-
};
将上面的两个文件生成动态库libaa.so放到 /usr/lib目录下,编译命令如下:
- sudo g++ -fpic -shared -g -o /usr/lib/libadd.so add.cpp -I ./
由于在C中不能识别类,所以要将上面类的成员函数封装成C接口函数输出,下面进行封装,将输出接口转换成C接口。
文件mylib.cpp
- //code in mylib.cpp
-
#include "add.h"
-
#ifndef _cplusplus
-
#define _cplusplus
-
#include "mylib.h"
-
#endif
-
-
int myfunc(int a, int b)
-
{
-
sample ss;
-
return ss.add(a, b);
-
}
文件
mylib.h
- //code in mylib.h
-
#ifdef _cplusplus
-
extern "C"
-
{
-
#endif
-
int myfunc(int a, int b);
-
#ifdef _cplusplus
-
}
-
#endif
在linux下,gcc编译器并没用变量_cplusplus来区分是C代码还是C++代码,如果使用gcc编译器,这里我们可以自己定义一个变量
_cplusplus用于区分C和C++代码,所以在mylib.cpp中定义了一个变量_cplusplus用于识别是否需要“extern
"C"”将函数接口封装成C接口。但是如果使用g++编译器则不需要专门定义_cplusplus,编译命令如下:
- g++ -fpic -shared -g -o mylib.so mylib.cpp -ladd -I ./
文件main.c
- //code in main.c
-
#include <stdio.h>
-
#include <dlfcn.h>
-
#include "mylib.h"
-
int
-
main()
-
{
-
int x = 3, y = 5, z;
-
int (*dlfunc)();
-
void *handle; //定义一个句柄
-
handle = dlopen("./mylib.so", RTLD_LAZY); //获得库句柄
-
dlfunc = dlsym(handle, "myfunc");//获得函数入口
-
z = (*dlfunc)(x, y);
-
printf("z = x + y = %d\n", z);
-
dlclose(handle);
-
return 0;
-
}
编译命令如下:
- gcc -o main main.c ./mylib.so -ldl
下面就可以执行了:
执行结果:
- sample::add() is
-
z = x + y = 8
需要说明的是,由于main.c 和
mylib.cpp都需要包含mylib.h,并且要将函数myfunc封装成C接口函数输出需要“extern "C"”,而C又不识别“extern
"C"”,所以需要定义_cplusplus来区别处理mylib.h中的函数myfunc。
在main.c的main函数中直接调用myfunc()函数也能执行,这里介绍的是常规调用库函数的方法。
阅读(4390) | 评论(0) | 转发(2) |