随着软件规模的扩大,要求的功能也是越来越多,开发人员的参与也是越来越多。因此软件的功能划分,就成为了现代软件工程的重大任务,还有软件开发的并行性也越来越重要。为了解决这些问题,大家都会看到IT硬件发展非常迅速,功能也越来越复杂,但硬件中发展明显提高在于采用IC的方式来实现复杂的功能,也就是把大部份功能集成到一起,只要给出一些引脚就可以实现产品了。而软件中有没有相同于硬件中的IC呢?我想是应有的,就是动态连接库了。在Windows这座大厦里,很多基石就是动态连接库构成的。一个动态连接库就封装了特别复杂的功能,使用者不必关心它是怎么样实现的。当然,这样也可以让不同的开发者同时开发产品,提高软件开发的速度。要使用动态连接库里的函数,就需要使用LoadLibrary函数来加载动态连接库,使用函数GetProcAddress来获取功能函数的地址。
函数LoadLibrary声明如下:
WINBASEAPI
__out
HMODULE
WINAPI
LoadLibraryA(
__in LPCSTR lpLibFileName
);
WINBASEAPI
__out
HMODULE
WINAPI
LoadLibraryW(
__in LPCWSTR lpLibFileName
);
#ifdef UNICODE
#define LoadLibrary LoadLibraryW
#else
#define LoadLibrary LoadLibraryA
#endif // !UNICODE
lpLibFileName是动态连接库的名称。
调用函数的例子如下:
#001 //加载动态连接库。
#002 //蔡军生 2007/12/03 qq:9073204 深圳
#003 void TestLoadDLL(void)
#004 {
#005 //加载动态连接库。
#006 HMODULE hDllLib = LoadLibrary(_T("Kernel32.dll"));
#007 if (hDllLib)
#008 {
#009 //获取动态连接库里的函数地址。
#010 FARPROC fpFun = GetProcAddress(hDllLib,"GetVersion");
#011
#012 //调用函数运行。
#013 DWORD dwVersion = (*fpFun)();
#014
#015 //获取WINDOWS的版本。
#016 DWORD dwWindowsMajorVersion = (DWORD)(LOBYTE(LOWORD(dwVersion)));
#017 DWORD dwWindowsMinorVersion = (DWORD)(HIBYTE(LOWORD(dwVersion)));
#018
#019 //显示。
#020 const int nBufSize = 512;
#021 TCHAR chBuf[nBufSize];
#022 ZeroMemory(chBuf,nBufSize);
#023
#024 wsprintf(chBuf,_T("显示版本:%d,%d\r\n"),
#025 dwWindowsMajorVersion,dwWindowsMinorVersion);
#026 OutputDebugString(chBuf);
#027
#028 //释放动态连接库。
#029 FreeLibrary(hDllLib);
#030 }
#031
#032 }
编缉推荐阅读以下文章
版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明!