在動(dòng)態(tài)庫和靜態(tài)庫中使用模板(dynamic libraries ,static libraries)
動(dòng)態(tài)導(dǎo)入庫和靜態(tài)庫: 他們實(shí)質(zhì)是不一樣的東西。靜態(tài)庫本身就包含了實(shí)際執(zhí)行代碼、符號(hào)表等等 ,而對(duì)于導(dǎo)入庫而言,其實(shí)際的執(zhí)行代碼位于動(dòng)態(tài)庫中,導(dǎo)入庫只包含了地址符號(hào)表等,確保程序找到對(duì)應(yīng)函數(shù)的一些基本地址信息
問題分析: 模板函數(shù)和模板類在庫中使用的時(shí)候 非常困難,但也不是不可能,因?yàn)橹挥邢鄳?yīng)參數(shù)類型的模板函數(shù)在庫內(nèi)部有實(shí)例,就能成功導(dǎo)出這個(gè)模板函數(shù)。對(duì)于模板類的公有成員函數(shù)們(包括構(gòu)造/析構(gòu)函數(shù))全部都必須有實(shí)例存在。
為什么要將模板實(shí)例化: 只有將導(dǎo)出庫里面的模板函數(shù)或者模板類實(shí)例化,才能將實(shí)例化后模板函數(shù)的地址信息和模板類實(shí)例化的地址信息保存在導(dǎo)出庫中。
示范:我還是以一個(gè)例子來說明吧,這是個(gè)動(dòng)態(tài)庫(dynamic libraries)的例子。
//<span style="font-family:'Microsoft YaHei';">TemplateLib.h</span><span style="font-family:'Microsoft YaHei';">使用動(dòng)態(tài)庫</span> #ifdefTEST_DLL_EXPORTS #define TEST_API__declspec(dllexport) #else #define TEST_API__declspec(dllimport) #endif // 導(dǎo)出模板函數(shù) template<typename T1> TEST_APIvoidfun1(T1); template<typename T1,typename T2> TEST_APIvoidfun2(T1 , T2); // 模板類 template<typename T,int size> class TEST_APICTest { public: CTest() {}; ~CTest(){}; T*GetDataBuff() { return m_data;} private: T m_data[size]; };
// TemplateLib.cpp : 定義 DLL 應(yīng)用程序的導(dǎo)出函數(shù)。 #include "stdafx.h" #include "TemplateLib.h" // 1.利用重載來實(shí)例化不同類型的模板,代碼量大不說,基本上是重復(fù)的代碼 // 2.庫的設(shè)計(jì)者不知道用戶會(huì)傳入什么類型,也就是說設(shè)計(jì)者不可能實(shí)例化每一種類型的模板。 TEST_APIvoid fun1(int var1) {} TEST_APIvoid fun1(char var1){} template<typename T1,typename T2> TEST_APIvoid fun2( T1 var1, T2 var2){} // 這個(gè)名字空間不作為導(dǎo)出使用,唯一作用是用來例化函數(shù)模板和類模板. namespace implement_template_private { voidimplement_template() { int idata = 10; charchr = 'x'; float fdata = 20.f; UINTundata= 9; char* str = "hello"; // 這種方式的實(shí)例化,代碼量比重載方式少許多,但需運(yùn)行一次該模板函數(shù) // 也許在某些時(shí)候憑空運(yùn)行這個(gè)函數(shù)是不合理的。 fun2(idata,chr);// int,char fun2(undata,str); // UINT,char* fun2<float,char*>(fdata,str); // float,char* 顯示參數(shù) // 導(dǎo)出類的實(shí)例化。 // 1.除了要實(shí)例化提供給用戶使用的公有成員函數(shù)外,這里面還隱含的實(shí)例化了構(gòu)造函數(shù)和析構(gòu)函數(shù). // 2.注意這里每一個(gè)模板的實(shí)例化都是唯一的。 // 3.假如客戶如果在項(xiàng)目中使用了CTest<char,30> impl_obj; 將會(huì)連接錯(cuò)誤, 模板的參數(shù)列表必須完全匹配。 // 4.假如該模板類非常大,功能非常多,那么實(shí)例化工作可以想象是不堪忍受的。 // 5.庫的設(shè)計(jì)者不知道用戶會(huì)傳入什么類型,也就是說設(shè)計(jì)者不可能實(shí)例化每一種類型的模板。 CTest<char,20>impl_obj; impl_obj.GetDataBuff(); CTest<int,5>impl_obj2; impl_obj.GetDataBuff(); } }; //
在另外一個(gè)項(xiàng)目中使用我們剛剛創(chuàng)建的動(dòng)態(tài)庫
// TemplateExport.cpp : 定義控制臺(tái)應(yīng)用程序的入口點(diǎn)。 // #include "stdafx.h" #include "..\TemplateLib\TemplateLib.h" #pragma comment(lib,"TemplateLib.lib") int _tmain(int argc, _TCHAR* argv[]) { fun1<int>(10); fun1<char>('x'); //fun1<float>(20.f);// 連接錯(cuò)誤 fun2<float,char*>(20,"hello"); //fun2<int,int>(20,30); // 連接錯(cuò)誤 CTest<char,20> test; char* ret = test.GetDataBuff(); //CTest<char,30> test2; // 連接錯(cuò)誤 return 0; }
總結(jié)與建議:不建議在導(dǎo)出庫中使用模板相關(guān)的技術(shù),假如你能夠確定用戶在使用你設(shè)計(jì)的模板函數(shù)時(shí),將傳入哪些類型(type),設(shè)計(jì)者要將這些類型的模板一 一實(shí)例化。
以上就是在動(dòng)態(tài)庫和靜態(tài)庫中使用模板解決方法的全部?jī)?nèi)容和代碼,希望我們的整理能夠幫助到你。
- Linux動(dòng)態(tài)庫函數(shù)的詳解
- Linux靜態(tài)庫與動(dòng)態(tài)庫實(shí)例詳解
- 詳解dll動(dòng)態(tài)庫的開發(fā)與調(diào)用及文件的讀寫小程序
- android studio2.3如何編譯動(dòng)態(tài)庫的過程詳解
- Linux下g++編譯與使用靜態(tài)庫和動(dòng)態(tài)庫的方法
- Linux環(huán)境g++編譯GDAL動(dòng)態(tài)庫操作方法
- 解決Linux程序編譯鏈接動(dòng)態(tài)庫版本的相關(guān)問題
- xcode 詳解創(chuàng)建靜態(tài)庫和動(dòng)態(tài)庫的方法
- 淺談Linux C語言動(dòng)態(tài)庫及靜態(tài)庫
- c++實(shí)現(xiàn)加載so動(dòng)態(tài)庫中的資源
- linux 程序、動(dòng)態(tài)庫、靜態(tài)庫內(nèi)部添加版本號(hào)和編譯時(shí)間詳解
- 從源碼編譯Android系統(tǒng)的Java類庫和JNI動(dòng)態(tài)庫的方法
- C#調(diào)用非托管動(dòng)態(tài)庫中的函數(shù)方法
- Visual Studio中根據(jù)系統(tǒng)區(qū)分引用64位、32位DLL動(dòng)態(tài)庫文件的配置方法
- 動(dòng)態(tài)庫調(diào)用靜態(tài)庫示例講解
- linux生成(加載)動(dòng)態(tài)庫靜態(tài)庫和加載示例方法
- 深入探討Linux靜態(tài)庫與動(dòng)態(tài)庫的詳解(一看就懂)
- 分析Windows和Linux動(dòng)態(tài)庫
相關(guān)文章
fatal error LNK1104: 無法打開文件“l(fā)ibc.lib”的解決方法
本篇文章是對(duì)fatal error LNK1104: 無法打開文件“l(fā)ibc.lib”的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05教你如何使用qt quick-PathView實(shí)現(xiàn)好看的home界面
pathView的使用類似與ListView,都需要模型(model)和代理(delegate),只不過pathView多了一個(gè)路徑(path)屬性,顧名思義路徑就是item滑動(dòng)的路徑,下面給大家分享qt quick-PathView實(shí)現(xiàn)好看的home界面,一起看看吧2021-06-06C語言動(dòng)態(tài)規(guī)劃多種背包問題分析講解
背包問題(Knapsack problem)是一種組合優(yōu)化的NP完全問題。問題可以描述為:給定一組物品,每種物品都有自己的重量和價(jià)格,在限定的總重量?jī)?nèi),我們?nèi)绾芜x擇,才能使得物品的總價(jià)格最高2022-04-04C++ OpenCV實(shí)現(xiàn)抖音"藍(lán)線挑戰(zhàn)"特效
這篇文章主要介紹了如何使用OpenCV C++ 實(shí)現(xiàn)抖音上的特效“藍(lán)線挑戰(zhàn)”。文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)OpenCV有一定的幫助,需要的可以參考一下2022-01-01如何判斷一個(gè)整數(shù)的二進(jìn)制中有多少個(gè)1
本篇文章是對(duì)如何判斷一個(gè)整數(shù)的二進(jìn)制中有多少個(gè)1的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C++Node類Cartographer開始軌跡的處理深度詳解
這篇文章主要介紹了C++Node類Cartographer開始軌跡的處理,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-03-03