Microsoft 在 Visual C++ 的 16 位編譯器版本中引入了 __export,使編譯器得以自動(dòng)生成導(dǎo)出名并將它們放到一個(gè) .lib 文件中。然后,此 .lib 文件就可以像靜態(tài) .lib 那樣用于與 DLL 鏈接。
在更新的編譯器版本中,可以使用 __declspec(dllexport) 關(guān)鍵字從 DLL 導(dǎo)出數(shù)據(jù)、函數(shù)、類或類成員函數(shù)。__declspec(dllexport) 會(huì)將導(dǎo)出指令添加到對(duì)象文件中,因此您不需要使用 .def 文件。
當(dāng)試圖導(dǎo)出 C++ 修飾函數(shù)名時(shí),這種便利最明顯。由于對(duì)名稱修飾沒(méi)有標(biāo)準(zhǔn)規(guī)范,因此導(dǎo)出函數(shù)的名稱在不同的編譯器版本中可能有所變化。如果使用__declspec(dllexport),僅當(dāng)解決任何命名約定更改時(shí)才必須重新編譯 DLL 和依賴 .exe 文件。
許多導(dǎo)出指令(如序號(hào)、NONAME 和 PRIVATE)只能在.def 文件中創(chuàng)建,并且必須使用 .def 文件來(lái)指定這些屬性。不過(guò),在 .def 文件的基礎(chǔ)上另外使用 __declspec(dllexport) 不會(huì)導(dǎo)致生成錯(cuò)誤。
若要導(dǎo)出函數(shù),__declspec(dllexport) 關(guān)鍵字必須出現(xiàn)在調(diào)用約定關(guān)鍵字的左邊(如果指定了關(guān)鍵字)。例如:
other
__declspec(dllexport) void __cdeclFunction1(void);
若要導(dǎo)出類中的所有公共數(shù)據(jù)成員和成員函數(shù),關(guān)鍵字必須出現(xiàn)在類名的左邊,如下所示:
other
class __declspec(dllexport) CExampleExport: public CObject
{ ... class definition ... };
生成 DLL 時(shí),通常創(chuàng)建一個(gè)包含正在導(dǎo)出的函數(shù)原型和/或類的頭文件,并將 __declspec(dllexport) 添加到頭文件中的聲明中。若要提高代碼的可讀性,請(qǐng)為 __declspec(dllexport) 定義一個(gè)宏并對(duì)正在導(dǎo)出的每個(gè)符號(hào)使用該宏:
other
#defineDllExport __declspec( dllexport )
__declspec(dllexport) 將函數(shù)名存儲(chǔ)在 DLL 的導(dǎo)出表中。如果希望優(yōu)化表的大小,請(qǐng)參見(jiàn)按序號(hào)而不是按名稱從 DLL 導(dǎo)出函數(shù)。
聯(lián)系客服