VC6.0如何創(chuàng)建以及調(diào)用動態(tài)鏈接庫實例詳解
更新時間:2013年01月03日 14:34:20 作者:
作為客戶與后臺的中介,為了更好的調(diào)節(jié)兩方的關(guān)系,我明智滴選擇了webservice以及動態(tài)鏈接庫。在與客戶c++使動態(tài)鏈接庫方式,而與后臺java,使用webservice來交流溝通
小弟在公司的職責,在上篇博客中已經(jīng)簡約介紹。這邊博客主要介紹技術(shù)的應(yīng)用而不在細究原理。因為公司項目著急,出結(jié)果要緊,并且咱也不是專注搞研究的,所以,基本懂了原理后,直接上手工作,搞出demo來最好。
至于公司工作情況,今天暫且略過,當然也不是一兩句能夠表達清楚的。后面會有相應(yīng)的工作總結(jié),敬請期待……
現(xiàn)在,廢話少說,直奔主題——VC6.0中創(chuàng)建動態(tài)鏈接庫。
作為客戶與后臺的中介,為了更好的調(diào)節(jié)兩方的關(guān)系,我明智滴選擇了webservice以及動態(tài)鏈接庫。在與客戶c++使動態(tài)鏈接庫方式,而與后臺java,使用webservice來交流溝通。
既然有了動態(tài)鏈接庫,肯定大家會想到靜態(tài)鏈接庫。呵呵,這個是相對的。那這兩者有什么區(qū)別呢?那又為什么選擇了動態(tài)鏈接庫呢?
靜態(tài)鏈接庫:是把lib文件也打包到了exe文件中。
動態(tài)鏈接庫:沒有把lib文件打包到exe文件中,若是使用,則直接加載卸載相應(yīng)的dll文件。
并且,靜態(tài)鏈接庫中不允許包含靜態(tài)鏈接庫和動態(tài)鏈接庫,而動態(tài)鏈接庫中是允許包含靜態(tài)鏈接庫和動態(tài)鏈接庫的。因為小弟封裝的dll中是調(diào)用客戶的dll,并且有可能包含另外自己的動態(tài)鏈接庫。
鑒于此,小弟選擇了動態(tài)鏈接庫。
還有一點是,動態(tài)鏈接庫,也是分為三種情況的。一是非MFC的dll(也就是控制臺的dll),二是常規(guī)的MFC的dll(其中又分靜態(tài)的dl和共享的dll),三是擴展的MFC 的dll。并且MFC的dll可以被MFC程序或者控制臺程序調(diào)用。
因為小弟封裝的dll,需要供MFC程序調(diào)用,所以選擇使用了MFC常規(guī)的dll。并且使用控制臺程序做測試。
首先,在新建工程中選擇MFC AppWizard (dll)
然后在頭.h文件中,聲明被外界調(diào)用的函數(shù)
extern "C" _declspec(dllexport) char* queryFunctionByFID(char* funcId);
聲明后,在cpp文件中,實現(xiàn)此函數(shù)。
char* queryFunctionByFID(char* funcId)
{
…………………………
具體的操作實現(xiàn)}
編譯,build生成。OK,在Debug下生成相應(yīng)的dll,至此動態(tài)鏈接庫生成了。然后程序就可以直接使用此dll文件了。
然后呢。把dll文件copy到相應(yīng)的測試dll程序(調(diào)用dll的程序)下。使用方式如下:
我測試dll程序中,是使用的控制臺程序,這樣簡單方便,當然使用MFC程序也可以。
比如:我們新建一個控制臺程序,然后在main方法中,寫如下:
//聲明函數(shù)指針 寫明函數(shù)參數(shù)個數(shù),參數(shù)類型以及返回值類型
typedef char* (* queryFunctionByFID)(char*);
//加載動態(tài)鏈接庫,返回DLL文件的句柄
HINSTANCE hDLL=NULL;
//加載動態(tài)鏈接庫,dll名稱要與剛才生成的dll名稱保持一致。
hDLL=LoadLibrary("IProcessInstIn.dll");
queryFunctionByFID saveProcess=NULL;
//加載動態(tài)鏈接庫中相應(yīng)的函數(shù)
saveProcess=(queryFunctionByFID)GetProcAddress(hDLL,"queryFunctionByFID");
//真正的調(diào)用相應(yīng)的函數(shù)
cout<<"結(jié)果是:"<<saveProcess("dd");
//調(diào)用完畢后釋放資源
FreeLibrary(hDLL);
每一句的作用,注釋已經(jīng)表達清楚。若是有不懂的,可以聯(lián)系我,互相交流一下。
其實,動態(tài)鏈接庫,類似我們VS中的dll,只不過,當時只要把dll引用到相應(yīng)的程序,然后直接可以使用。而在此,是我們手動加載,連接,釋放dll。使用這種方式的動態(tài)鏈接庫,我們可以很隨意在我們程序中的任何地方都可以使用我們想調(diào)用的函數(shù)。
只要我們遵守了“加載,LoadLibrary——GetProcAddress——FreeLibrary”原則即可。使用相當方便。即可解脫了兩者之間耦合的困擾,又可以加載釋放方便。
調(diào)用靜態(tài)鏈接庫的做法如下:
第一:把lib文件和dll文件兩個文件全部放在客戶端下,調(diào)用動態(tài)鏈接庫時,只需要dll文件。
第二:在客戶端中需要新建頭文件,類似dll中的導(dǎo)出函數(shù)的頭文件。
第三:在客戶端調(diào)用dll文件中(cpp文件),添加預(yù)指令,也就是把lib文件顯式加載進來。
如:#pragma comment (lib,"IProcessInstIn.dll")
第四:在button事件下,直接調(diào)用相應(yīng)的方法。
如:cout<<"結(jié)果是:"<<queryFunctionByFID(相應(yīng)的參數(shù));
總之,調(diào)用靜態(tài)鏈接庫,相對于來說,比較簡單,只要把相應(yīng)的文件加載進來后,直接調(diào)用方法即可。但是調(diào)用動態(tài)鏈接庫相對來說,比較靈活,何時使用何時加載,不使用了直接卸載即可。
任何事物都有優(yōu)缺點,我們呢,就是充分利用他們的優(yōu)點,在不同的場合不同的需求下使用不同的方式。
剛才我們在生成dll時,使用Debug版本下的dll,既然有可以選擇Debug版本,根據(jù)我們的思維,肯定會想到,存在另外的版本。下篇博客中,我們會介紹一下Debug版本下的動態(tài)鏈接庫和另一個版本Release版本下的動態(tài)鏈接庫的區(qū)別,以及何時何地選擇何種版本。
至于公司工作情況,今天暫且略過,當然也不是一兩句能夠表達清楚的。后面會有相應(yīng)的工作總結(jié),敬請期待……
現(xiàn)在,廢話少說,直奔主題——VC6.0中創(chuàng)建動態(tài)鏈接庫。
作為客戶與后臺的中介,為了更好的調(diào)節(jié)兩方的關(guān)系,我明智滴選擇了webservice以及動態(tài)鏈接庫。在與客戶c++使動態(tài)鏈接庫方式,而與后臺java,使用webservice來交流溝通。
既然有了動態(tài)鏈接庫,肯定大家會想到靜態(tài)鏈接庫。呵呵,這個是相對的。那這兩者有什么區(qū)別呢?那又為什么選擇了動態(tài)鏈接庫呢?
靜態(tài)鏈接庫:是把lib文件也打包到了exe文件中。
動態(tài)鏈接庫:沒有把lib文件打包到exe文件中,若是使用,則直接加載卸載相應(yīng)的dll文件。
并且,靜態(tài)鏈接庫中不允許包含靜態(tài)鏈接庫和動態(tài)鏈接庫,而動態(tài)鏈接庫中是允許包含靜態(tài)鏈接庫和動態(tài)鏈接庫的。因為小弟封裝的dll中是調(diào)用客戶的dll,并且有可能包含另外自己的動態(tài)鏈接庫。
鑒于此,小弟選擇了動態(tài)鏈接庫。
還有一點是,動態(tài)鏈接庫,也是分為三種情況的。一是非MFC的dll(也就是控制臺的dll),二是常規(guī)的MFC的dll(其中又分靜態(tài)的dl和共享的dll),三是擴展的MFC 的dll。并且MFC的dll可以被MFC程序或者控制臺程序調(diào)用。
因為小弟封裝的dll,需要供MFC程序調(diào)用,所以選擇使用了MFC常規(guī)的dll。并且使用控制臺程序做測試。
首先,在新建工程中選擇MFC AppWizard (dll)
然后在頭.h文件中,聲明被外界調(diào)用的函數(shù)
復(fù)制代碼 代碼如下:
extern "C" _declspec(dllexport) char* queryFunctionByFID(char* funcId);
聲明后,在cpp文件中,實現(xiàn)此函數(shù)。
復(fù)制代碼 代碼如下:
char* queryFunctionByFID(char* funcId)
{
…………………………
具體的操作實現(xiàn)}
編譯,build生成。OK,在Debug下生成相應(yīng)的dll,至此動態(tài)鏈接庫生成了。然后程序就可以直接使用此dll文件了。
然后呢。把dll文件copy到相應(yīng)的測試dll程序(調(diào)用dll的程序)下。使用方式如下:
我測試dll程序中,是使用的控制臺程序,這樣簡單方便,當然使用MFC程序也可以。
比如:我們新建一個控制臺程序,然后在main方法中,寫如下:
復(fù)制代碼 代碼如下:
//聲明函數(shù)指針 寫明函數(shù)參數(shù)個數(shù),參數(shù)類型以及返回值類型
typedef char* (* queryFunctionByFID)(char*);
//加載動態(tài)鏈接庫,返回DLL文件的句柄
HINSTANCE hDLL=NULL;
//加載動態(tài)鏈接庫,dll名稱要與剛才生成的dll名稱保持一致。
hDLL=LoadLibrary("IProcessInstIn.dll");
queryFunctionByFID saveProcess=NULL;
//加載動態(tài)鏈接庫中相應(yīng)的函數(shù)
saveProcess=(queryFunctionByFID)GetProcAddress(hDLL,"queryFunctionByFID");
//真正的調(diào)用相應(yīng)的函數(shù)
cout<<"結(jié)果是:"<<saveProcess("dd");
//調(diào)用完畢后釋放資源
FreeLibrary(hDLL);
每一句的作用,注釋已經(jīng)表達清楚。若是有不懂的,可以聯(lián)系我,互相交流一下。
其實,動態(tài)鏈接庫,類似我們VS中的dll,只不過,當時只要把dll引用到相應(yīng)的程序,然后直接可以使用。而在此,是我們手動加載,連接,釋放dll。使用這種方式的動態(tài)鏈接庫,我們可以很隨意在我們程序中的任何地方都可以使用我們想調(diào)用的函數(shù)。
只要我們遵守了“加載,LoadLibrary——GetProcAddress——FreeLibrary”原則即可。使用相當方便。即可解脫了兩者之間耦合的困擾,又可以加載釋放方便。
調(diào)用靜態(tài)鏈接庫的做法如下:
第一:把lib文件和dll文件兩個文件全部放在客戶端下,調(diào)用動態(tài)鏈接庫時,只需要dll文件。
第二:在客戶端中需要新建頭文件,類似dll中的導(dǎo)出函數(shù)的頭文件。
第三:在客戶端調(diào)用dll文件中(cpp文件),添加預(yù)指令,也就是把lib文件顯式加載進來。
如:#pragma comment (lib,"IProcessInstIn.dll")
第四:在button事件下,直接調(diào)用相應(yīng)的方法。
如:cout<<"結(jié)果是:"<<queryFunctionByFID(相應(yīng)的參數(shù));
總之,調(diào)用靜態(tài)鏈接庫,相對于來說,比較簡單,只要把相應(yīng)的文件加載進來后,直接調(diào)用方法即可。但是調(diào)用動態(tài)鏈接庫相對來說,比較靈活,何時使用何時加載,不使用了直接卸載即可。
任何事物都有優(yōu)缺點,我們呢,就是充分利用他們的優(yōu)點,在不同的場合不同的需求下使用不同的方式。
剛才我們在生成dll時,使用Debug版本下的dll,既然有可以選擇Debug版本,根據(jù)我們的思維,肯定會想到,存在另外的版本。下篇博客中,我們會介紹一下Debug版本下的動態(tài)鏈接庫和另一個版本Release版本下的動態(tài)鏈接庫的區(qū)別,以及何時何地選擇何種版本。
相關(guān)文章
詳細分析C++ 數(shù)據(jù)封裝和數(shù)據(jù)抽象
這篇文章主要介紹了C++ 數(shù)據(jù)封裝和數(shù)據(jù)抽象的的相關(guān)資料,文中代碼非常詳細,幫助大家更好的理解和學習,感興趣的朋友可以了解下2020-06-06
c語言使用fdk_aac實現(xiàn)aac音頻解碼為pcm
這篇文章主要為大家詳細介紹了c語言如何使用fdk_aac庫實現(xiàn)aac音頻解碼為pcm的功能,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下2023-11-11
GCC編譯過程(預(yù)處理,編譯,匯編,鏈接)及GCC命令詳解
文章詳細介紹了GCC編譯器的工作原理,包括預(yù)處理、編譯、匯編和鏈接四個主要階段,每個階段都有其特定的任務(wù)和輸出文件,文章還解釋了如何使用GCC命令選項來查看每個階段的輸出,以及如何通過調(diào)整編譯選項來優(yōu)化程序性能或調(diào)試問題,感興趣的朋友跟隨小編一起看看吧2024-11-11

