在开发过程中,只有so库但是没有函数引用的头文件,但是又想调用里面的方法,因此,可以动态加载so,进行调so中的方法。具体步骤如下:
1.创建add.c文件
vim add.c
int add(int a,int b)
{
return a+b;
}
2.生产动态库
在add.c的目录下,执行命令,后会生成 libadd.so
-fPIC 生成 PIC 代码,.so 要求为 PIC,以达到动态链接的目的,否则,无法实现动态链接
-shared 动态库
-o 生成目标的文件名
gcc -shared -fPIC add.c -o libadd.so
3.编写调用so函数
#include <stdio.h>
#include <stdlib.h>
#include <dlfcn.h>
typedef int (*Add)(int,int);
int main()
{
//RTLD_NOW:在dlopen返回前,解析出全部没有定义的符号,解析不出来返回NULL。
//RT_GLOBAL:动态库定义的符号可被其后打开的其他库解析。
//RT_LOCAL:和上面相反,不能被其他库解析。默认。
//RTLD_LAZY:暂缓决定,等有需要时再解出符号
void *handle=dlopen("./libadd.so",RTLD_LAZY);
Add add=NULL;
*(void **)(&add)=dlsym(handle,"add");
int result=add(1,2);
printf("1 + 2 = %d \n",result);
return 0;
}
4.编译生成可执行文件
在main.c的目录下,执行命令,后会生成 main 可执行文件
-rdynamic 生成可执行文件
-o 目标文件名
gcc -rdynamic -o main main.c -ldl
5.测试
./main
输出结果:
1+ 2 =3