我正在为虚拟机进行本机调用绑定,其中一个功能是能够在运行时按名称查找标准libc函数.在
Windows上,这会变得有点麻烦,因为我需要获取当前在进程中加载的msvcrt模块的句柄.通常这是msvcrt.dll,但它也可能是其他变种(msvcr100.dll等),如果使用具有不同名称的变体,则对GetModuleHandle(“msvcrt”)的调用可能会失败.
我希望能够做的是反向查找,从libc中获取函数指针(我有很多)并获得提供它的模块的句柄.基本上,这样的事情:
HANDLE hlibc = ReverseGetModuleHandle(fprintf); // Any func from libc should do the trick void *vfunc = GetProcAddress(hlibc);
在win32 API中是否有这样的东西,而不是下载到进程句柄和符号表的手动遍历?相反,如果我过度思考问题,是否有更简单的方法在win32上按名称查找libc函数?
MEMORY_BASIC_INFORMATION mbi; HMODULE mod; if (VirtualQuery( vfunc,&mbi,sizeof(mbi) )) { mod = (HMODULE)mbi.AllocationBase; }