来仔细解读一下DllMain的函数头BOOL APIENTRY DllMain( HANDLE hModule, WORD ul_reason_for_call, LPVOID lpReserved )。 APIENTRY被定义为__stdcall,它意味着这个函数以标准Pascal的方式进行调用,也就是WINAPI方式; 进程中的每个DLL模块被全局唯一的32字节的HINSTANCE句柄标识,只有在特定的进程内部有效,句柄代表了DLL模块在进程虚拟空间中的起始地址。在Win32中,HINSTANCE和HMODULE的值是相同的,这两种类型可以替换使用,这就是函数参数hModule的来历。 执行下列代码: hDll = LoadLibrary("..\\Debug\\dllTest.dll"); 我们看到输出顺序为: process attach of dll call add in dll:5 process detach of dll 这一输出顺序验证了DllMain被调用的时机。 代码中的GetProcAddress ( hDll, MAKEINTRESOURCE ( 1 ) )值得留意,它直接通过.def文件中为add函数指定的顺序号访问add函数,具体体现在MAKEINTRESOURCE ( 1 ),MAKEINTRESOURCE是一个通过序号获取函数名的宏,定义为(节选自winuser.h): #define MAKEINTRESOURCEA(i) (LPSTR)((DWORD)((WORD)(i))) |
正在阅读:VC++动态链接库(DLL)编程深入浅出(二)VC++动态链接库(DLL)编程深入浅出(二)
2005-09-14 09:45
出处:PConline
责任编辑:moningfeng
键盘也能翻页,试试“← →”键