共用方式為


使用 __declspec(dllexport) 從 DLL 匯出

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 ... };
注意事項注意事項

__declspec(dllexport) 無法套用至使用 __clrcall 呼叫慣例的函式。

在建置 DLL 時,您通常會建立標頭檔 (Header File),包含要匯出之函式的原型和/或類別,並在標頭檔的宣告中加入 __declspec(dllexport)。 若要使程式更容易讀取,請為 __declspec(dllexport) 定義巨集,並在每個輸出的符號使用巨集:

#define DllExport   __declspec( dllexport ) 

__declspec(dllexport) 會將函式名稱儲存在 DLL 的匯出表。 如果您要最佳化表格的大小,請參閱根據序數而不是名稱從 DLL 匯出函式

注意事項注意事項

將 DLL 原始程式碼從 Win16 移植到 Win32 時,請將每個 __export 執行個體取代為 __declspec(dllexport)

請搜尋整個 Win32 Winbase.h 標頭檔做為參考。 其中包含了 __declspec(dllimport) 的用法範例。

您想要怎麼做?

您還想知道關於哪些方面的詳細資訊?

請參閱

概念

從 DLL 匯出