dlopen用法参数flag介绍

1. 包含头文件  #include<dlfcn.h>

2. 函数定义 void * dlopen(const char* pathName, int mode);

pathName 指的是db文件或listDB.so文件在实机环境中的位置, mode指的是打开数据库的模式

mode在linux下,按功能有以下几种

解析方式:

RTLD_LAZY:暂缓决定,在dlopen返回前,对于动态库中的未定义的符号不执行解析(只对函数引用有效,对于变量引用总是立即解析)

RTLD_NOW:立即决定,在dlopen返回前,解析出所有未定义的符号,如果解析不出来,在dlopen会返回NULL,错误为 undefined symbol:XXX...

作用范围:

RTLD_GLOBAL: 动态库中定义的符号可被其后打开的其他库重定位

RTLD_LOCAL: 与RTLD_GLOBAL作用相反,动态库中定义的符号不能被其后打开的其他库重定位。如果没有指明是RTLD_GLOBAL还是RTLD_LOCAL,那么

默认是RTLD_LOCAL。

作用方式:

RTLD_NODELETE:在dlclose()期间不卸载库,并且在以后使用dlopen()重新加载库时不初始化库中的静态变量。这个flag不是POSIX-2001标准。

RTLD_NOLOAD: 不加载库,可用于测试库是否已经加载(dlopen()返回NULL说明未加载,否则说明加载),也可用于改变已加载库的flag,

如:先前加载库的flag为RTLD_LOCAL,用dlopen(RTLD_NOLOAD|RTLD_GLOBAL)后flag将变成RTLD_GLOBAL.这个flag不是POSIX-2001标准

RTLD_DEEPBIND:在搜索全局符号前先搜索库内的符号,避免同名符号的冲突,这个flag不是POSIX-2001标准

 

3. 返回值void*,如果成功则返回引用这个数据库的句柄,如果失败则返回NULL

编译时要加入 -ldl(指定dl库)

ey:gcc test.c -o test -ldl

posted @ 2021-05-07 10:01  小鼬就是我  阅读(871)  评论(0编辑  收藏  举报