以下是调用Dll中函数的代码
HINSTANCE h
h=LoadLibrary("hook.dll");//定义一个函数指针变量:
int (*fnA)(int, int);
*((FARPROC*)(&fnA)) = GetProcAddress(h,"fnA");
int x=fnA(3,5);
FreeLibrary(h);
问:请帮我详细解释一下*((FARPROC*)(&fnA))的含义 ,特别是&的意思
HINSTANCE h
h=LoadLibrary("hook.dll");//定义一个函数指针变量:
int (*fnA)(int, int);
*((FARPROC*)(&fnA)) = GetProcAddress(h,"fnA");
int x=fnA(3,5);
FreeLibrary(h);
问:请帮我详细解释一下*((FARPROC*)(&fnA))的含义 ,特别是&的意思
当中这么一个转换,只是为了让编译器能够接受这样一个赋值。如果你还不能很好理解,可以这样看:
FARPROC *pfnA = (FARPROC*)(&fnA);
*pfnA = GetProcAddress(h,"fnA");
上面的代码类似于这样的:
UINT nResult;
DWORD nVal;
要把nResult赋给nVal:
UINT *pnVal = (UINT *)(&nVal);
*pnVal = nResult;
当然,仅仅把要把nResult赋给nVal,没必要这么复杂,这里只是举个例子。
fnA毕竟要放一个32位的地址值, 而他的类型是 int (...)(int, int) 型。
FARPROC的原型定义,我懒得查,总之不是int (...)(int, int) 型。如果你 fnA = LoadLibaray().编译器会认为是错误转换。为了实现该功能,必须骗编译器说 &fnA 里面希望放了一个FARPROC, 你就给我吧!!!。实现的方法很多:
FARPROC f = LoadLibaray();
memcpy(&fnA, &f, sizeof(fnA));
也行,总之就是往fnA里填入LoadLibaray()的返回值。
GetProcAddressz() 写成了 LoadLibaray()
( FARPROC ) fnA = GetProcAddress(h, "fnA");
但在实际情况中,编译器会告之我们:
error C2106: '=' : left operand must be l-value
解决之道有二:
其一:把GetProcAddress的return value转换成我们所需要的:
fnA = ( int (*) ( int, int ) ) GetProcAddress(h, "fnA" );
其二:或者,如你看到的,先把取fnA的地址(就是&符号的作用),再把返回的pointer转换成GetProcAddress的return value的类型,最后,用解引用操作符(dereference operator,就是*),来读写实际内容:
( (FARPROC*) ( &fnA ) ) = GetProcAddress (h, "fnA" );
第一个回答你的人用“FARPROC *pfnA = (FARPROC*)(&fnA);”来说明,这样的解释很对。