dlopen 介绍

dlopen 介绍dlopen nbsp 介绍 includevoid dlopen constchar filename intflag char dlerror void void dlsym void handle constchar symbol intdlclose void handle 打开一个动态链接库 并返回动态链接库的句柄 flag

dlopen 介绍

 
   
  1. #include
  2. void *dlopen(const char *filename, int flag);
  3. char *dlerror(void);
  4. void *dlsym(void *handle, const char *symbol);
  5. int dlclose(void *handle);

打开一个动态链接库,并返回动态链接库的句柄。

flag


  1. 解析方式

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

    RTLD_NOW: 需要在dlopen返回前,解析出所有未定义符号,如果解析不出来,在dlopen会返回NULL,错误为:: undefined symbol: xxxx.


  2. 作用范围,可与解析方式通过“|”组合使用。


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


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


  3. 作用方式


    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标准。

返回值:

打开错误返回NULL

成功,返回库引用

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

dlsym

    根据动态链接库操作句柄与符号,返回符号对应的地址。

dlclose

    关闭执行句柄的动态连接库,只有当此动态链接库的使用技术为0时,才会真正被系统卸载。


    成功时返回0.


dlerror

    返回最后一次调用dlopen、dlsym或dlclose的错误信息


    


   
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/203433.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月19日 下午9:48
下一篇 2026年3月19日 下午9:49


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号