__declspec(dllimport)
生活随笔
收集整理的這篇文章主要介紹了
__declspec(dllimport)
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
我相信寫WIN32程序的人,做過DLL,都會很清楚__declspec(dllexport)的作用,它就是為了省掉在DEF文件中手工定義導(dǎo)出哪些函數(shù)的一個方法。當然,如果你的DLL里全是C++的類的話,你無法在DEF里指定導(dǎo)出的函數(shù),只能用__declspec(dllexport)導(dǎo)出類。但是,MSDN文檔里面,對于__declspec(dllimport)的說明讓人感覺有點奇怪,先來看看MSDN里面是怎么說的: 不使用 __declspec(dllimport) 也能正確編譯代碼,但使用 __declspec(dllimport) 使編譯器可以生成更好的代碼。編譯器之所以能夠生成更好的代碼,是因為它可以確定函數(shù)是否存在于 DLL 中,這使得編譯器可以生成跳過間接尋址級別的代碼,而這些代碼通常會出現(xiàn)在跨 DLL 邊界的函數(shù)調(diào)用中。但是,必須使用 __declspec(dllimport) 才能導(dǎo)入 DLL 中使用的變量。 初看起來,這段話前面的意思是,不用它也可以正常使用DLL的導(dǎo)出庫,但最后一句話又說,必須使用 __declspec(dllimport) 才能導(dǎo)入 DLL 中使用的變量這個是什么意思?? 那我就來試驗一下,假定,你在DLL里只導(dǎo)出一個簡單的類,注意,我假定你已經(jīng)在項目屬性中定義了 SIMPLEDLL_EXPORT
SimpleDLLClass.h #ifdef SIMPLEDLL_EXPORT
#define DLL_EXPORT __declspec(dllexport)
#else
#define DLL_EXPORT
#endif class DLL_EXPORT SimpleDLLClass
{
public:
SimpleDLLClass();
virtual ~SimpleDLLClass(); virtual getValue() { return m_nValue;};
private:
int m_nValue;
};
SimpleDLLClass.cpp #include "SimpleDLLClass.h" SimpleDLLClass::SimpleDLLClass()
{
m_nValue=0;
} SimpleDLLClass::~SimpleDLLClass()
{
}
然后你再使用這個DLL類,在你的APP中include SimpleDLLClass.h時,你的APP的項目不用定義 SIMPLEDLL_EXPORT 所以,DLL_EXPORT 就不會存在了,這個時候,你在APP中,不會遇到問題。這正好對應(yīng)MSDN上說的__declspec(dllimport)定義與否都可以正常使用。但我們也沒有遇到變量不能正常使用呀。 那好,我們改一下SimpleDLLClass,把它的m_nValue改成static,然后在cpp文件中加一行 int SimpleDLLClass::m_nValue=0;
如果你不知道為什么要加這一行,那就回去看看C++的基礎(chǔ)。 改完之后,再去LINK一下,你的APP,看結(jié)果如何, 結(jié)果是LINK告訴你找不到這個m_nValue。明明已經(jīng)定義了,為什么又沒有了?? 肯定是因為我把m_nValue定義為static的原因。但如果我一定要使用Singleton的Design Pattern的話,那這個類肯定是要有一個靜態(tài)成員,每次LINK都沒有,那不是完了? 如果你有Platform SDK,用里面的Depend程序看一下,DLL中又的確是有這個m_nValue導(dǎo)出的呀。
再回去看看我引用MSDN的那段話的最后一句。 那我們再改一下SimpleDLLClass.h,把那段改成下面的樣子: #ifdef SIMPLEDLL_EXPORT
#define DLL_EXPORT __declspec(dllexport)
#else
#define DLL_EXPORT __declspec(dllimport)
#endif
再LINK,一切正常。原來dllimport是為了更好的處理類中的靜態(tài)成員變量的,如果沒有靜態(tài)成員變量,那么這個__declspec(dllimport)無所謂。 _declspec(dllexport)與_declspec(dllimport)的區(qū)別 2009-04-29 22:49
SimpleDLLClass.h #ifdef SIMPLEDLL_EXPORT
#define DLL_EXPORT __declspec(dllexport)
#else
#define DLL_EXPORT
#endif class DLL_EXPORT SimpleDLLClass
{
public:
SimpleDLLClass();
virtual ~SimpleDLLClass(); virtual getValue() { return m_nValue;};
private:
int m_nValue;
};
SimpleDLLClass.cpp #include "SimpleDLLClass.h" SimpleDLLClass::SimpleDLLClass()
{
m_nValue=0;
} SimpleDLLClass::~SimpleDLLClass()
{
}
然后你再使用這個DLL類,在你的APP中include SimpleDLLClass.h時,你的APP的項目不用定義 SIMPLEDLL_EXPORT 所以,DLL_EXPORT 就不會存在了,這個時候,你在APP中,不會遇到問題。這正好對應(yīng)MSDN上說的__declspec(dllimport)定義與否都可以正常使用。但我們也沒有遇到變量不能正常使用呀。 那好,我們改一下SimpleDLLClass,把它的m_nValue改成static,然后在cpp文件中加一行 int SimpleDLLClass::m_nValue=0;
如果你不知道為什么要加這一行,那就回去看看C++的基礎(chǔ)。 改完之后,再去LINK一下,你的APP,看結(jié)果如何, 結(jié)果是LINK告訴你找不到這個m_nValue。明明已經(jīng)定義了,為什么又沒有了?? 肯定是因為我把m_nValue定義為static的原因。但如果我一定要使用Singleton的Design Pattern的話,那這個類肯定是要有一個靜態(tài)成員,每次LINK都沒有,那不是完了? 如果你有Platform SDK,用里面的Depend程序看一下,DLL中又的確是有這個m_nValue導(dǎo)出的呀。
再回去看看我引用MSDN的那段話的最后一句。 那我們再改一下SimpleDLLClass.h,把那段改成下面的樣子: #ifdef SIMPLEDLL_EXPORT
#define DLL_EXPORT __declspec(dllexport)
#else
#define DLL_EXPORT __declspec(dllimport)
#endif
再LINK,一切正常。原來dllimport是為了更好的處理類中的靜態(tài)成員變量的,如果沒有靜態(tài)成員變量,那么這個__declspec(dllimport)無所謂。 _declspec(dllexport)與_declspec(dllimport)的區(qū)別 2009-04-29 22:49
| _declspec(dllexport)與_declspec(dllimport) 都是DLL內(nèi)的關(guān)鍵字,即導(dǎo)出與導(dǎo)入。他們是將DLL內(nèi)部的類與函數(shù)以及數(shù)據(jù)導(dǎo)出與導(dǎo)入時使用的。主要區(qū)別在于,dllexport是在這些類、函數(shù)以及數(shù)據(jù)的申明的時候使用。用過表明這些東西可以被外部函數(shù)使用,即(dllexport)是把DLL中的相關(guān)代碼(類,函數(shù),數(shù)據(jù))暴露出來為其他應(yīng)用程序使用。使用了(dllexport)關(guān)鍵字,相當于聲明了緊接在(dllexport)關(guān)鍵字后面的相關(guān)內(nèi)容是可以為其他程序使用的。而dllimport關(guān)鍵字是在外部程序需要使用DLL內(nèi)相關(guān)內(nèi)容時使用的關(guān)鍵字。當一個外部程序要使用DLL內(nèi)部代碼(類,函數(shù),全局變量)時,只需要在程序內(nèi)部使用(dllimport)關(guān)鍵字聲明需要使用的代碼就可以了,即(dllimport)關(guān)鍵字是在外部程序需要使用DLL內(nèi)部相關(guān)內(nèi)容的時候才使用。(dllimport)作用是把DLL中的相關(guān)代碼插入到應(yīng)用程序中。 _declspec(dllexport)與_declspec(dllimport)是相互呼應(yīng),只有在DLL內(nèi)部用dllexport作了聲明,才能在外部函數(shù)中用dllimport導(dǎo)入相關(guān)代碼。實際上,在應(yīng)用程序訪問DLL時,實際上就是應(yīng)用程序中的導(dǎo)入函數(shù)與DLL文件中的導(dǎo)出函數(shù)進行鏈接。而且鏈接的方式有兩種:隱式迎接和顯式鏈接。 隱式鏈接是指通過編譯器提供給應(yīng)用程序關(guān)于DLL的名稱和DLL函數(shù)的鏈接地址,面在應(yīng)用程序中不需要顯式地將DLL加載到內(nèi)存,即在應(yīng)用程序中使用dllimport即表明使用隱式鏈接。不過不是所有的隱式鏈接都使用dllimport。 顯式鏈接剛同應(yīng)用程序用語句顯式地加載DLL,編譯器不需要知道任何關(guān)DLL的信息。 |
轉(zhuǎn)載于:https://blog.51cto.com/laokaddk/260371
總結(jié)
以上是生活随笔為你收集整理的__declspec(dllimport)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: display:inline-block
- 下一篇: VBScript 教程之数据库篇