我想知道是否有可能,使用 C 和 WindowsAPI,是否有一个函数可以让我获得 dll 中函数的 32 位(我认为)内存地址。例如。如何获取 kernel32.dll 中 Beep() 的 32 位 $xxxxxxxx 地址。其次,如果我在汇编中使用内存地址而不是函数名,是否可以避免链接。例如
mov eax, $xxxxxxxx
代替
mov eax, Beep
该程序将打印地址Beep
在内核32中:
#include <windows.h>
#include <stdio.h>
int main(void)
{
HMODULE hMod = GetModuleHandle("kernel32.dll");
void* fn = GetProcAddress(hMod, "Beep");
printf("%p", fn);
}
为了简单起见,我省略了错误检查。在真实的程序中你不会这样做。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)