获取DLL函数的内存地址

时间:2014-01-27 14:59:15

标签: c windows winapi memory dll

我想知道是否有可能,使用C和WindowsAPI,如果有一个函数可以得到我在dll中的函数的32位(我认为)内存地址。例如。如何在kernel32.dll中获取Beep()的32位$ xxxxxxxx地址。其次,如果我在汇编中使用内存地址而不是函数名,我可以避免链接。例如

mov eax, $xxxxxxxx

而不是

mov eax, Beep

2 个答案:

答案 0 :(得分:2)

是。在MSDN上查找“GetProcAddress”。

答案 1 :(得分:2)

该程序将在kernel32中打印Beep的地址:

#include <windows.h>
#include <stdio.h>

int main(void)
{
    HMODULE hMod = GetModuleHandle("kernel32.dll");
    void* fn = GetProcAddress(hMod, "Beep");
    printf("%p", fn);
}

为了简单起见,我省略了错误检查。在真正的程序中你不会这样做。