HANDLE,HMODULE,HINSTANCE,HWND概念

本文介绍了Windows系统中不同类型的句柄,包括Handle、HMODULE、HINSTANCE和HWND的区别与联系,并通过示例代码展示了如何加载DLL并调用其中的函数。

Handle 是代表系统的内核对象,如文件句柄,线程句柄,进程句柄。
HMODULE 是代表应用程序载入的模块,win32系统下通常是被载入模块的线性地址。
HINSTANCE 在win32下与HMODULE是相同的东西,在Win32下还存在主要是因为win16
 程序使用HINSTANCE来区别task。
HWND 是窗口句柄。

HMODULE等同于HINSTANCE 

下面是我写的测试代码:

 void testfun()

{

 typedef int (_stdcall *FUN)(int,int,int);
 HMODULE hInst = LoadLibrary(_T("Test.dll"));
 if(hInst!=NULL)
 {
  FUN pFun =  (FUN)GetProcAddress(hInst,"TestFun");
  if(pFun !=NULL)
  {
 TestFun();
  }
 }
 else
 {
  ::AfxMessageBox("找不到TestDll");
 }

}

将HMODULE hInst = LoadLibrary(_T("Test.dll")) 替换成  HINSTANCE hInst = LoadLibrary(_T("Test.dll")) 

编译通过。
 

C:\Users\admin\Desktop\未命名1.cpp In function 'void SetAutoStart()': 17 43 C:\Users\admin\Desktop\未命名1.cpp [Error] cannot convert 'wchar_t*' to 'LPSTR {aka char*}' for argument '2' to 'DWORD GetModuleFileNameA(HMODULE, LPSTR, DWORD)' 19 94 C:\Users\admin\Desktop\未命名1.cpp [Error] cannot convert 'const wchar_t*' to 'LPCSTR {aka const char*}' for argument '2' to 'LONG RegOpenKeyA(HKEY, LPCSTR, PHKEY)' 20 94 C:\Users\admin\Desktop\未命名1.cpp [Error] cannot convert 'const wchar_t*' to 'LPCSTR {aka const char*}' for argument '2' to 'LONG RegSetValueExA(HKEY, LPCSTR, DWORD, DWORD, const BYTE*, DWORD)' C:\Users\admin\Desktop\未命名1.cpp In function 'bool IsAlreadyRunning()': 26 76 C:\Users\admin\Desktop\未命名1.cpp [Error] cannot convert 'const wchar_t*' to 'LPCSTR {aka const char*}' for argument '3' to 'void* CreateMutexA(LPSECURITY_ATTRIBUTES, WINBOOL, LPCSTR)' C:\Users\admin\Desktop\未命名1.cpp In function 'void TimerProc(HWND, UINT, UINT_PTR, DWORD)': 39 36 C:\Users\admin\Desktop\未命名1.cpp [Error] cannot convert 'const wchar_t*' to 'LPCSTR {aka const char*}' for argument '2' to 'WINBOOL SetWindowTextA(HWND, LPCSTR)' C:\Users\admin\Desktop\未命名1.cpp In function 'LRESULT WindowProc(HWND, UINT, WPARAM, LPARAM)': 50 72 C:\Users\admin\Desktop\未命名1.cpp [Error] cannot convert 'const wchar_t*' to 'LPCSTR {aka const char*}' for argument '2' to 'HWND__* CreateWindowExA(DWORD, LPCSTR, LPCSTR, DWORD, int, int, int, int, HWND, HMENU, HINSTANCE, LPVOID)' 52 42 C:\Users\admin\Desktop\未命名1.cpp [Error] converting to execution character set: Illegal byte sequence 64 51 C:\Users\admin\Desktop\未命名1.cpp [Error] cannot convert 'wchar_t*' to 'LPSTR {aka char*}' for argument '2' to 'int GetWindowTextA(HWND, LPSTR, int)' 68 38 C:\Users\admin\Desktop\未命名1.cpp [Error] converting to execution character set: Illegal byte sequence 68 69 C:\Users\admin\Desktop\未命名1.cpp [Error] converting to execution character set: Illegal byte sequence 70 38 C:\Users\admin\Desktop\未命名1.cpp [Error] converting to execution character set: Illegal byte sequence 70 67 C:\Users\admin\Desktop\未命名1.cpp [Error] converting to execution character set: Illegal byte sequence 80 30 C:\Users\admin\Desktop\未命名1.cpp [Error] converting to execution character set: Illegal byte sequence 80 57 C:\Users\admin\Desktop\未命名1.cpp [Error] converting to execution character set: Illegal byte sequence C:\Users\admin\Desktop\未命名1.cpp In function 'bool CreateMainWindow(HINSTANCE)': 106 22 C:\Users\admin\Desktop\未命名1.cpp [Error] cannot convert 'const wchar_t [29]' to 'LPCSTR {aka const char*}' in assignment 113 24 C:\Users\admin\Desktop\未命名1.cpp [Error] converting to execution character set: Illegal byte sequence C:\Users\admin\Desktop\未命名1.cpp In function 'void RestartIfKilled()': 130 43 C:\Users\admin\Desktop\未命名1.cpp [Error] cannot convert 'wchar_t*' to 'LPSTR {aka char*}' for argument '2' to 'DWORD GetModuleFileNameA(HMODULE, LPSTR, DWORD)' 134 16 C:\Users\admin\Desktop\未命名1.cpp [Error] cannot convert 'const wchar_t [5]' to 'LPCSTR {aka const char*}' in assignment 135 16 C:\Users\admin\Desktop\未命名1.cpp [Error] cannot convert 'wchar_t [260]' to 'LPCSTR {aka const char*}' in assignment C:\Users\admin\Desktop\未命名1.cpp In function 'int wWinMain(HINSTANCE, HINSTANCE, LPWSTR, int)': 156 26 C:\Users\admin\Desktop\未命名1.cpp [Error] converting to execution character set: Illegal byte sequence 156 45 C:\Users\admin\Desktop\未命名1.cpp [Error] converting to execution character set: Illegal byte sequence
09-14
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值