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; }

相关文章

迭代器模式(Iterator)迭代器模式(Iterator)[Cursor]意图...
高性能IO模型浅析服务器端编程经常需要构造高性能的IO模型,...
策略模式(Strategy)策略模式(Strategy)[Policy]意图:定...
访问者模式(Visitor)访问者模式(Visitor)意图:表示一个...
命令模式(Command)命令模式(Command)[Action/Transactio...
生成器模式(Builder)生成器模式(Builder)意图:将一个对...