建立和使用動態鏈結庫 C

2021-06-07 08:04:45 字數 4173 閱讀 6103

我們將建立的第一種型別的庫是動態鏈結庫 (dll)。

使用 dll 是一種重用**的絕佳方式。

您不必在自己建立的每個程式中重新實現同一例程,而只需對這些例程編寫一次,然後從需要該功能的應用程式引用它們即可。

本演練涵蓋以下內容:

本主題假定您具備 c++ 語言的基礎知識。

從「檔案」選單中,選擇「新建」,然後選擇「專案…」。

在「專案型別」窗格中,選擇「visual c++」下的「win32」。

在「模板」窗格中,選擇「win32 控制台應用程式」。

為專案選擇乙個名稱,如 mathfuncsdll,並將其鍵入「名稱」字段。

為解決方案選擇乙個名稱,如 dynamiclibrary,並將其鍵入「解決方案名稱」字段。

單擊「確定」啟動 win32 應用程式嚮導。

在「win32 應用程式嚮導」對話方塊的「概述」頁中,單擊「下一步」。

在「win32 應用程式嚮導」中的「應用程式設定」頁中,選擇「應用程式型別」下的「dll」(如果可用),或者選擇「控制台應用程式」(如果「dll」不可用)。

某些版本的 visual studio 不支援通過使用嚮導建立 dll 專案。

您可以稍後對此進行更改,以將專案編譯為 dll。

在「win32 應用程式嚮導」的「應用程式設定」頁中,選擇「附加選項」下的「空專案」。

單擊「完成」建立專案。

若要為新類建立標頭檔案,請從「專案」選單中選擇「新增新項…」。

將顯示「新增新項」對話方塊。

在「類別」窗格中,選擇「visual c++」下的「**」。

在「模板」窗格中選擇「標頭檔案(.h)」。

為標頭檔案選擇乙個名稱,如 mathfuncsdll.h,並單擊「新增」。

將顯示乙個空白檔案。

新增乙個名為「mymathfuncs」的簡單類,以執行常見的算術運算,如加、減、乘和除。

**應與以下內容類似:

// mathfuncsdll.h

namespace mathfuncs

;}

請注意此**方法宣告中的 __declspec(dllexport) 修飾符。

這些修飾符使 dll 能夠匯出該方法以供其他應用程式使用。

有關更多資訊,請參見 dllexport, dllimport。

若要為新類建立原始檔,請從「專案」選單中選擇「新增新項…」。

將顯示「新增新項」對話方塊。

在「類別」窗格中,選擇「visual c++」下的「**」。

在「模板」窗格中,選擇「c++ 檔案(.cpp)」。

為原始檔選擇乙個名稱,如 mathfuncsdll.cpp,並單擊「新增」。

將顯示乙個空白檔案。

在原始檔中實現「mymathfuncs」的功能。

**應與以下內容類似:

// mathfuncsdll.cpp

// compile with: /ehsc /ld

#include "mathfuncsdll.h"

#include using namespace std;

namespace mathfuncs

double mymathfuncs::subtract(double a, double b)

double mymathfuncs::multiply(double a, double b)

double mymathfuncs::divide(double a, double b)

return a / b;}}

若要將專案生成為 dll,請從「專案」選單中選擇 mathfuncsdll「屬性...」。

在左窗格中,選擇「配置屬性」下的「常規」。

在右窗格中,將「配置型別」更改為「動態庫(.dll)」。

單擊「確定」儲存更改。

注意

如果您從命令列生成專案,請使用/ld編譯器選項指定輸出檔案應為 dll。

有關更多資訊,請參見 /md、/mt、/ld(使用執行庫)。

編譯該動態鏈結庫,方法是選擇「生成」選單中的「生成解決方案」。

這樣就建立了乙個可供其他程式使用的 dll。

有關 dll 的詳細資訊,請參見 dll。

若要建立將引用並使用剛建立的動態鏈結庫的應用程式,請從「檔案」選單中選擇「新建」,然後選擇「專案...」。

在「專案型別」窗格中,選擇「visual c++」下的「win32」。

在「模板」窗格中,選擇「win32 控制台應用程式」。

為專案選擇乙個名稱(如 myexecrefsdll),並將其鍵入「名稱」字段。

從「解決方案」旁邊的下拉列表中選擇「添入解決方案」。

這會將新專案新增到該動態鏈結庫所屬的同乙個解決方案中。

單擊「確定」啟動「win32 應用程式嚮導」。

在「win32 應用程式嚮導」對話方塊的「概述」頁中,單擊「下一步」。

在「win32 應用程式嚮導」的「應用程式設定」頁中,選擇「應用程式型別」下的「控制台應用程式」。

在「win32 應用程式嚮導」的「應用程式設定」頁中,清除「附加選項」下的「預編譯頭」核取方塊。

按「完成」建立專案。

建立新的控制台應用程式後,將為您建立乙個空程式。

原始檔的名稱與您在前面為專案選擇的名稱相同。

在本示例中,名為「myexecrefsdll.cpp」。

若要使用在動態鏈結庫中建立的算術例程,則必須引用該庫。

若要執行此操作,請在解決方案資源管理器中選擇 myexecrefsdll 專案,然後從「專案」選單中選擇「引用...」。

在「屬性頁」對話方塊中,展開「通用屬性」節點,選擇「框架和引用」,然後選擇「新增新引用...」按鈕。

有關「引用...」對話方塊的更多資訊,請參見「屬性頁」對話方塊 ->「通用屬性」->「框架和引用」。

顯示「新增引用」對話方塊。

此對話方塊列出了所有可以引用的庫。

「專案」選項卡列出了當前解決方案中的所有專案,以及它們包含的所有庫。

在「專案」選項卡中,選擇 mathfuncsdll。

然後單擊「確定」。

若要引用動態鏈結庫的標頭檔案,必須修改包含目錄路徑。

為此,請在「屬性頁」對話方塊中展開「配置屬性」節點,然後展開「c/c++」節點,並選擇「常規」。

在「附加包含目錄」旁邊,鍵入 mathfuncsdll.h 標頭檔案所在位置的路徑。

可執行檔案僅在執行時載入動態鏈結庫。

必須告訴系統在**查詢「mathfuncsdll.dll」。

您可以通過使用path環境變數做到這一點。

為此,請在「屬性頁」對話方塊中展開「配置屬性」節點,並選擇「除錯」。

在「環境」旁邊鍵入以下內容:path=<

mathfuncsdll.dll 檔案的路,其中 <

mathfuncsdll.dll 檔案的路徑》 應替換為 mathfuncsdll.dll 的實際位置。

單擊「確定」儲存所有更改。

注意

如果要從命令列而不是從 visual studio 執行可執行檔案,則必須在命令提示符處手動更新path環境變數,如下所示:set path=%path%;<

mathfuncsdll.dll 檔案的路,其中

現在,可以在應用程式中使用「mymathfuncs」類了。

使用以下**替換「myexecrefsdll.cpp」的內容:

// myexecrefsdll.cpp

// compile with: /ehsc /link mathfuncsdll.lib

#include #include "mathfuncsdll.h"

using namespace std;

int main()

通過從「生成」選單中選擇「生成解決方案」,生成可執行檔案。

確保選擇「myexecrefsdll」作為預設專案。

在「解決方案資源管理器」中,選擇 myexecrefsdll,然後選擇「專案」選單中的「設為啟動專案」。

若要執行專案,請選擇「除錯」選單中的「開始執行(不除錯)」。

輸出應該與下面的內容類似:

a + b = 106.4

a - b = -91.6

a * b = 732.6

a / b = 0.0747475

建立和使用動態鏈結庫 C

visual studio 2008 其他版本 22 共 24 對本文的評價是有幫助 評價此主題 更新 2007 年 11 月 我們將建立的第一種型別的庫是動態鏈結庫 dll 使用 dll 是一種重用 的絕佳方式。您不必在自己建立的每個程式中重新實現同一例程,而只需對這些例程編寫一次,然後從需要該功...

C 建立和使用動態鏈結庫

乙個簡單的動態鏈結庫的生成和呼叫例子,太過簡單,大神請繞道。使用vs建立工程選擇動態鏈結庫。在專案中建立原始檔和標頭檔案,並在檔案中新增以下 在標頭檔案中新增以下 dlltest.h 標頭檔案,使用動態鏈結庫時需要包含標頭檔案 pragma once ifdef dllexport define d...

C 建立和使用動態鏈結庫

乙個簡單的動態鏈結庫的生成和呼叫例子,太過簡單,大神請繞道。使用vs建立工程選擇動態鏈結庫。在專案中建立原始檔和標頭檔案,並在檔案中新增以下 在標頭檔案中新增以下 dlltest.h 標頭檔案,使用動態鏈結庫時需要包含標頭檔案 pragma once ifdef dllexport define d...