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