我想知道是否有可能,使用C和WindowsAPI,如果有一个函数可以得到我在dll中的函数的32位(我认为)内存地址。例如。如何在kernel32.dll中获取Beep()的32位$ xxxxxxxx地址。其次,如果我在汇编中使用内存地址而不是函数名,我可以避免链接。例如
mov eax, $xxxxxxxx
而不是
mov eax, Beep
答案 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);
}
为了简单起见,我省略了错误检查。在真正的程序中你不会这样做。