Microsoft 在 Visual C++ 的 16 位元編譯器 (Compiler) 版本中引入 __export,讓編譯器可自動產生匯出名稱並將他們置於 .lib 檔中。接著就可以像靜態 .lib 檔一樣,使用這個 .lib 檔連結至 DLL。
在新版本的編譯器中,您可以使用 __declspec(dllexport) 關鍵字匯出 DLL 的資料、函式、類別或類別成員函式。__declspec(dllexport) 會將匯出指示詞加入至物件檔,這樣您就不需用到 .def 檔。
這種便利性在嘗試匯出修飾 C++ 函式名稱時最為明顯。因為名稱裝飾 (Name Decoration) 並無標準規格,所以匯出函式的名稱在不同編譯器版本之間可能會有所變更。如果您使用 __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 時,您通常會建立標頭檔 (Header File),包含要匯出之函式的原型和/或類別,並在標頭檔的宣告中加入 __declspec(dllexport)。若要使程式更容易讀取,請為 __declspec(dllexport)定義巨集,並在每個輸出的符號使用巨集:
#define DllExport __declspec( dllexport )
注意事項
|
將 DLL 原始程式碼從 Win16 移植到 Win32 時,請將每個 __export 執行個體取代為 __declspec(dllexport)。
|
請搜尋整個 Win32 Winbase.h 標頭檔做為參考。其中包含了 __declspec(dllimport) 的用法範例。
沒有留言:
張貼留言