Win32程序 (生成DLL库及加载DLL库方法)

动态链接库(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函数)将其从内存中卸载。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

New_HackerHK

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值