动态链接库(Dynamic Link Library,简称DLL)是一种可重用的代码库,它包含了许多函数和数据,可以被不同的程序共享和调用。与静态链接库相比,DLL文件在程序运行时才被加载到内存中,并且可以在运行时被载入或卸载,从而实现动态的功能扩展和模块化开发。
- 生成DLL库
#include <windows.h>
BOOL APIENTRY DllMain(HMODULE hModule,
DWORD ul_reason_for_call,
LPVOID lpReserved)
{
switch (ul_reason_for_call)
{
case DLL_PROCESS_ATTACH:
// 当DLL被进程加载时执行的操作
break;
case DLL_THREAD_ATTACH:
// 当线程创建时执行的操作
break;
case DLL_THREAD_DETACH:
// 当线程结束时执行的操作
break;
case DLL_PROCESS_DETACH:
// 当DLL从进程中卸载时执行的操作
break;
}
return TRUE;
}
extern "C" __declspec(dllexport) void hello()
{
OutputDebugString(L"Hello,New-HackerHK");
}
- 加载DLL库
#include <windows.h>
// 定义函数指针类型
typedef int (*HELLO)();
int main() {
// 加载DLL文件
HINSTANCE hModule = LoadLibrary(L"../x64/Debug/dll.dll");
if (hModule == NULL) {
return 1;
}
// 获取函数地址
HELLO hello = (HELLO)GetProcAddress(hModule, "hello");
if (NULL != hello) {
// 调用函数
hello();
}
// 卸载DLL文件
FreeLibrary(hModule);
return 0;
}
创建DLL:编写包含需要共享的函数和数据的源代码,并将其编译为DLL文件。
加载DLL:在程序中通过调用动态链接库相关的API函数(例如LoadLibrary函数)加载DLL文件到内存中。
导入函数:在程序中定义函数指针,并通过调用GetProcAddress函数获取DLL中导出函数的地址。
调用函数:通过函数指针调用DLL中的函数,以实现相应的功能。
卸载DLL:在程序不再需要使用DLL时,通过调用动态链接库相关的API函数(例如FreeLibrary函数)将其从内存中卸载。