dlopen与动态链接库的依赖

前端之家收集整理的这篇文章主要介绍了dlopen与动态链接库的依赖前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

有两个动态链接库,其中一个依赖了另一个定义的函数,使用dlopen的时候,需要加上RTLD_GLOBAL。

动态库一,life,定义了一个life函数

gcc -shared -Wl,-soname,liblife.so.1 -o liblife.so.1.0 life.c

---------------------------------------------------------------------

#include <stdio.h>
#include <stdlib.h>
#include <dlfcn.h>

int life(int a)
{
return a+8;
}

动态库二,printk,其中调用了动态库一定义的life函数

gcc -shared -Wl,libprintk.so.1 -o libprintk.so.1.0 printk.c

----------------------------------------------------------------------

#include <stdio.h>
#include <stdlib.h>
#include <dlfcn.h>

extern int life(int a);

void printk(char *con)
{
printf("%s %d/n",con,life(1));
return;
}

主程序,用dlopen打开了两个动态链接

gcc -o foo foo.c -ldl

-------------------------------------------------------------------

#include <stdio.h>
#include <stdlib.h>
#include <dlfcn.h>

int day(int a)
{
return a+2;
}

int main(int argc,char **argv) {
void *handle1,*handle2;
void (*printk)(char *);
int (*life)(int a);
char *error;
handle2 = dlopen ("./liblife.so.1.0",RTLD_LAZY | RTLD_GLOBAL );
if (!handle2) {
fprintf (stderr,"%s/n",dlerror());
exit(1);
}
dlerror(); /* Clear any existing error */
handle1 = dlopen ("./libprintk.so.1.0",RTLD_LAZY | RTLD_GLOBAL ); if (!handle1) { fprintf (stderr,dlerror()); exit(1); } dlerror(); /* Clear any existing error */ life = dlsym(handle2,"life"); if ((error = dlerror()) != NULL) { fprintf (stderr,error); exit(1); } printk = dlsym(handle1,"printk"); if ((error = dlerror()) != NULL) { fprintf (stderr,error); exit(1); } printf("%d/n",life(1)); printk("hhh"); dlclose(handle1); dlclose(handle2); return 0; }

猜你在找的设计模式相关文章