Microsoft 在 Visual C++ 的 16 位編譯器版本中引入了 __export,使編譯器得以自動生成導出名並將它們放到一個 .lib 文件中。然後,此 .lib 文件就可以像靜態 .lib 那樣用於與 DLL 鏈接。
在更新的編譯器版本中,可以使用 __declspec(dllexport) 關鍵字從 DLL 導出數據、函數、類或類成員函數。__declspec(dllexport) 會將導出指令添加到對象文件中,因此您不需要使用 .def 文件。
當試圖導出 C++ 修飾函數名時,這種便利最明顯。由於對名稱修飾沒有標準規範,因此導出函數的名稱在不同的編譯器版本中可能有所變化。如果使用 __declspec(dllexport),僅當解決任何命名約定更改時才必須重新編譯 DLL 和依賴 .exe 文件。
許多導出指令(如序號、NONAME 和 PRIVATE)只能在 .def 文件中創建,並且必須使用 .def 文件來指定這些屬性。不過,在 .def 文件的基礎上另外使用 __declspec(dllexport) 不會導致生成錯誤。
若要導出函數,__declspec(dllexport) 關鍵字必須出現在調用約定關鍵字的左邊(如果指定了關鍵字)。例如:
__declspec(dllexport) void __cdecl Function1(void);
若要導出類中的所有公共數據成員和成員函數,關鍵字必須出現在類名的左邊,如下所示:
class __declspec(dllexport) CExampleExport : public CObject { ... class definition ... };
生成 DLL 時,通常創建一個包含正在導出的函數原型和/或類的頭文件,並將 __declspec(dllexport) 添加到頭文件中的聲明中。若要提高代碼的可讀性,請爲 __declspec(dllexport) 定義一個宏並對正在導出的每個符號使用該宏:
#define DllExport __declspec( dllexport )
__declspec(dllexport) 將函數名存儲在 DLL 的導出表中。如果希望優化表的大小,請參見按序號而不是按名稱從 DLL 導出函數。
注意 |
---|
將 DLL 源代碼從 Win16 移植到 Win32 時,請用 __declspec(dllexport) 替換 __export 的每個實例。 |
作爲參考,請在 Win32 Winbase.h 頭文件中搜索。它包含 __declspec(dllimport) 的用法示例。