dll 文件加载

LoadLibrary函数
随着软件规模的扩大,要求的功能也是越来越多,开发人员的参与也是越来越多。因此软件的功能划分,就成为了现代软件工程的重大任务,还有软件开发的并行性也越来越重要。为了解决这些问题,大家都会看到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是动态连接库的名称。

调用函数的例子如下:

//加载动态连接库。
 void TestLoadDLL(void)
{
    //加载动态连接库。
    HMODULE hDllLib = LoadLibrary(_T("Kernel32.dll"));
    if (hDllLib)
    {
        //获取动态连接库里的函数地址。
        FARPROC fpFun = GetProcAddress(hDllLib,"GetVersion");           
        //调用函数运行。
        DWORD dwVersion = (*fpFun)();             
       //获取WINDOWS的版本。
       DWORD dwWindowsMajorVersion = (DWORD)(LOBYTE(LOWORD(dwVersion)));
       DWORD dwWindowsMinorVersion = (DWORD)(HIBYTE(LOWORD(dwVersion)));              
       //显示。
       const int nBufSize = 512;
       TCHAR chBuf[nBufSize];
       ZeroMemory(chBuf,nBufSize);
       wsprintf(chBuf,_T("显示版本:%d,%d\r\n"),
       dwWindowsMajorVersion,dwWindowsMinorVersion);
       OutputDebugString(chBuf);
       //释放动态连接库。
       FreeLibrary(hDllLib);
       }        
}

你可能感兴趣的:(软件工程)