当前位置: 首页 > news >正文

[特殊字符] GUNION SDK 接口调用方式说明(静态库 vs 动态库)

文章目录

  • 💡 GUNION SDK 接口调用方式说明(静态库 vs 动态库)
    • 📘 一、接口宏定义说明
    • 🚀 二、使用方式对比
    • 🧱 三、调用方使用方式详解
      • ✅ 1. 使用静态库(.lib)
      • ✅ 2. 使用 DLL(隐式链接)
      • ✅ 3. 使用 DLL(动态加载 LoadLibrary)
    • 🔍 四、导出名注意事项(运行时加载)
    • 📦 五、推荐发布内容(给调用者)
    • ✅ 六、宏设置汇总

💡 GUNION SDK 接口调用方式说明(静态库 vs 动态库)

本手册详细介绍 Ghome.h 接口文件在不同调用场景下的使用方式,包括宏控制、链接方式、运行时行为、适配代码等,确保调用方能够正确配置并调用 SDK 接口。


📘 一、接口宏定义说明

Ghome.h 中,使用如下宏控制导出/导入行为:

#if defined(GHOME_STATIC)#define GHOME_API
#elif defined(GHOME_EXPORTS)#define GHOME_API __declspec(dllexport)
#else#define GHOME_API __declspec(dllimport)
#endif

含义如下:

宏定义含义说明
GHOME_STATIC表示使用静态库(.lib),不需要 DLL
GHOME_EXPORTS表示正在编译 DLL,导出符号(供别人用)
未定义任何宏默认行为,表示正在使用 DLL(导入符号)

🚀 二、使用方式对比

使用场景是否需要定义宏是否使用 .lib是否需要 .dll是否使用 LoadLibrary
✅ 静态库 .lib 编译链接#define GHOME_STATIC✅ 是❌ 否❌ 否
✅ DLL(隐式链接)无需定义宏✅ 是✅ 是❌ 否
✅ DLL(运行时动态加载)❌ 不需要宏❌ 否✅ 是✅ 是

🧱 三、调用方使用方式详解

✅ 1. 使用静态库(.lib)

  • 头文件中添加宏:
#define GHOME_STATIC
#include "Ghome.h"
  • 链接设置:
    • 链接 .lib 文件(例如:ghome_static.lib
    • 不需要运行时存在 .dll
  • 示例代码:
GhomeLAppInfo appInfo = { sizeof(GhomeLAppInfo), 123, L"游戏名", L"1.0", -1, -1 };
int ret = GhomeInitialize(&appInfo);

✅ 2. 使用 DLL(隐式链接)

  • 不需要定义任何宏
  • 工程中链接 .lib 文件(由 DLL 编译生成);
  • 运行时需要 .dll 文件放在可执行文件旁边或系统 PATH 中。
  • 示例代码:
#include "Ghome.h"GhomeLAppInfo appInfo = { sizeof(GhomeLAppInfo), 123, L"游戏名", L"1.0", -1, -1 };
int ret = GhomeInitialize(&appInfo);

✅ 3. 使用 DLL(动态加载 LoadLibrary)

  • 不需要包含 ghome.h(除非重用 struct 定义)
  • 使用 typedef 声明函数指针
  • 使用 LoadLibraryGetProcAddress 动态调用
  • 示例代码:
typedef int (__cdecl *PF_GhomeInitialize)(const GhomeLAppInfo*);
HMODULE hDll = LoadLibraryW(L"`sdologinsdk.dll`");
if (hDll) {PF_GhomeInitialize init = (PF_GhomeInitialize)GetProcAddress(hDll, "GhomeInitialize");if (init) {GhomeLAppInfo appInfo = { sizeof(GhomeLAppInfo), 123, L"游戏名", L"1.0", -1, -1 };int ret = init(&appInfo);}FreeLibrary(hDll);
}
  • 优点: 不需链接 .lib,运行时灵活控制加载;
  • 缺点: 函数名大小写必须匹配,需手动定义所有函数指针;

🔍 四、导出名注意事项(运行时加载)

使用 GetProcAddress 加载函数时,需要确认 DLL 中函数是否为标准 C 导出名(例如 GhomeInitialize)而不是带修饰符的(如 _GhomeInitialize@4)。建议:

  • 在 C++ 中使用 extern "C" 包裹导出声明;
  • 使用 dumpbin /exports ghome.dll 验证导出名;
  • 保证函数名在头文件与 DLL 中完全一致。

📦 五、推荐发布内容(给调用者)

建议发布以下内容给调用者:

文件名描述
ghome.h公共头文件
sdologinsdk.lib、sdologinsdk64.lib静态库文件(如使用静态库)
sdologinsdk.dll、sdologinsdk64.dll动态库运行时文件
sdologinsdk.lib、sdologinsdk64.libDLL 的 import 库(隐式链接时用)

✅ 六、宏设置汇总

使用方式推荐设置
静态链接#define GHOME_STATIC
DLL 编译#define GHOME_EXPORTS
DLL 调用不定义宏(默认导入)
动态加载 DLL不定义宏,自定义函数指针
http://www.xdnf.cn/news/616717.html

相关文章:

  • 树莓派的刷机和登录
  • 常见证书格式区别
  • 矩阵详解:线性代数在AI大模型中的核心支柱
  • win11 24H2 版本,运行.vbs错误:没有文件扩展“.vbs“的脚本引擎
  • 夺命充电何时休?电瓶车入室起火事件频发
  • Linux C/C++编程 —— 线程技术总结
  • 家政维修平台实战09:推送数据到多维表格
  • 得力DE-620K针式打印机打印速度不能调节维修一例
  • AI Engine Kernel and Graph Programming--知识分享6
  • 深度探讨:AI 的全能边界 —— 哪些任务仍超越当前技术范畴?
  • 高校外卖小程序,怎么落地实践?
  • echarts之折线柱状图
  • 【ISP算法精粹】ISP算法管线的预处理算法有哪些?
  • Linux之 SPI 驱动框架- spi-mem 框架
  • 虚拟化工具libvirt日志文件的结构化使用指南
  • Python 脚本执行命令的深度探索:方法、示例与最佳实践
  • 蓝桥杯2025.5.23每日一题-儿童数
  • 中科驭数携DPU全栈产品亮相福州数博会,赋能智算时代算力基建
  • Trae 的核心功能介绍
  • OS面试篇
  • BU9792驱动段式LCD
  • C++:无序容器
  • 第十四届蓝桥杯国赛PythonA题解
  • Ubuntu系统下,使用system函数运行终端指令,如何避免输入密码的方法
  • 大数据任务调度实战:DolphinScheduler 与 Airflow 深度解析与最佳实践
  • DAX权威指南4:时间智能计算
  • C++ 结构体封装模式与 Promise 链式调用:设计思想的异曲同工
  • 广东省省考备考(第十八天5.23)—言语:语句填空题(听课后强化训练)
  • Calculix,基于有限元法 (fem) 的免费工具
  • AdGuard解锁高级版(Nightly)_v4.10.36 安卓去除手机APP广告