0

0

c++怎么在运行时动态加载库(dll/so)_c++跨平台动态链接库加载方法

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-11-14 21:44:50

|

231人浏览过

|

来源于php中文网

原创

在C++中通过封装LoadLibrary/GetProcAddress和dlopen/dlsym实现跨平台动态库加载,Windows使用HMODULE,Linux/Unix使用void*,统一接口支持插件系统。

c++怎么在运行时动态加载库(dll/so)_c++跨平台动态链接库加载方法

在C++中实现运行时动态加载库(Windows下的DLL和Linux/Unix下的SO)是一项常见的跨平台需求,比如插件系统或模块化架构。虽然不同操作系统提供的API不同,但可以通过封装统一接口来实现跨平台兼容。

Windows: 使用 LoadLibrary 和 GetProcAddress

在Windows平台上,使用 LoadLibrary(或 LoadLibraryEx)加载DLL,用 GetProcAddress 获取函数地址,FreeLibrary 释放库。

示例代码:

#include 
#include 

typedef int (*AddFunc)(int, int);

int main() { HMODULE lib = LoadLibrary(L"example.dll"); if (!lib) { std::cerr << "无法加载DLL" << std::endl; return -1; }

AddFunc add = (AddFunc)GetProcAddress(lib, "add");
if (!add) {
    std::cerr << "无法获取函数地址" << std::endl;
    FreeLibrary(lib);
    return -1;
}

std::cout << "结果: " << add(2, 3) << std::endl;

FreeLibrary(lib);
return 0;

}

立即学习C++免费学习笔记(深入)”;

Linux/Unix: 使用 dlopen 和 dlsym

在类Unix系统中,通过 dlopen 加载共享库(.so),dlsym 获取符号地址,dlclose 释放库。

编译时需链接 dl 库:-ldl

超级简历WonderCV
超级简历WonderCV

免费求职简历模版下载制作,应届生职场人必备简历制作神器

下载
#include 
#include 

typedef int (*AddFunc)(int, int);

int main() { void* lib = dlopen("./libexample.so", RTLD_LAZY); if (!lib) { std::cerr << "无法加载SO: " << dlerror() << std::endl; return -1; }

AddFunc add = (AddFunc)dlsym(lib, "add");
const char* error = dlerror();
if (error) {
    std::cerr << "无法获取函数: " << error << std::endl;
    dlclose(lib);
    return -1;
}

std::cout << "结果: " << add(2, 3) << std::endl;

dlclose(lib);
return 0;

}

立即学习C++免费学习笔记(深入)”;

跨平台封装示例

为了实现跨平台,可以封装一个简单的动态库加载类:

#ifdef _WIN32
    #include 
    using LibHandle = HMODULE;
    #define LOAD_LIB(name) LoadLibraryA(name)
    #define GET_FUNC(lib, name) GetProcAddress(lib, name)
    #define FREE_LIB(lib) FreeLibrary(lib)
#else
    #include 
    using LibHandle = void*;
    #define LOAD_LIB(name) dlopen(name, RTLD_LAZY)
    #define GET_FUNC(lib, name) dlsym(lib, name)
    #define FREE_LIB(lib) dlclose(lib)
#endif

class DynamicLib { public: explicit DynamicLib(const char* path) { handle = LOAD_LIB(path); }

~DynamicLib() {
    if (handle) FREE_LIB(handle);
}

void* getFunction(const char* name) {
    return GET_FUNC(handle, name);
}

bool isValid() const { return handle != nullptr; }

private: LibHandle handle = nullptr; };

使用方式:

DynamicLib lib("example.dll"); // 或 libexample.so
if (lib.isValid()) {
    auto add = (AddFunc)lib.getFunction("add");
    if (add) std::cout << add(2, 3) << std::endl;
}

注意事项与建议

  • C++存在函数名修饰(name mangling),推荐在导出函数前加上 extern "C" 防止重命名,确保符号可被正确查找。
  • 确保库的路径正确,相对路径可能因工作目录不同而失败,建议使用绝对路径。
  • 加载失败时及时处理错误(Windows用GetLastError,Linux用dlerror)。
  • 注意库的依赖关系,目标机器需具备运行所需的所有依赖库。
  • 跨平台构建时,可用CMake统一管理不同平台的编译规则。

基本上就这些。只要封装好平台差异,并规范导出接口,C++动态加载库并不复杂,但容易忽略细节导致运行失败。

相关专题

更多
javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

173

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

92

2025.11.27

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

989

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

50

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

225

2025.12.29

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

516

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1051

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

748

2023.08.01

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

62

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.4万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号