API 文檔生成(C# dll)
當前位置:點晴教程→知識管理交流
→『 技術文檔交流 』
一、Sandcastle這個是c#類庫方法根據注釋生成幫助文檔的工具,我們經常會遇到把DLL或者API提供給別人調用的情況,通過在方法中添加注釋,然后再用Sandcastle 來自動生成文檔給調用者,如下圖: 圖1:這是Sandcastle Help File Builder軟件界面 圖2:這是生成的chm文檔 還可以直接給出示例代碼:
二、下載安裝下載地址: Help File Builder and Tools v2021.4.9.0最新版本 下載鏈接:https://github.com/EWSoftware/SHFB/releases 單純Sandcastle好像是沒有界面的, 這個鏈接提供的下載可以包含圖形界面。 注意:如果需要生成chm還需要微軟的 MicrosoftHTMLHelpWorkshop 支持,Sandcastle生成時會自動去查找MicrosoftHTMLHelpWorkshop 的安裝目錄。 安裝: 安裝很簡單,兩個軟件都只需要直接點擊“下一步”即可安裝完成。 三、Sandcastle配置安裝好軟件后可以根據自己的需要配置相應的參數。 默認情況下dll中所有方法和屬性都會生成對應文檔,也可以根據自己需要只把DLL中需要的類或方法生成文檔,可通過如下圖配置: 在左側把需要的類或方法勾選就行了: 在使用工具生成文檔前,別忘了在VS中要作簡單配置,才能生成DLL對應的XML配置文件,vs配置方法如下: 在VS中右鍵項目屬性: 把"XML documentation file:"勾選,當編譯時在生成DLL的同時還會生成一個和dll同名的xml配置文件。 在Sandcastle中右側窗口右鍵將需要生成文檔的dll和對應的xml添加進來: 點擊工具欄上的 這個按鈕就可以自動生成文檔了。 四、C#注釋規范為了生成友好的幫助文檔,注釋規范自然少不了,以下是關于C#的注釋規范以及各參數的說明,注釋越詳細,生成的文檔可讀性越好: 1、C#注釋標記: 大家對注釋應該都不陌生,在方法或者類前面三個斜杠就自動添加了常用的注釋標記,如下圖: 但是如果想要得到更加友好的幫助文檔,注釋得花點心思。 如文章開頭所展示的幫助文檔,部分方法的注釋如下: 2、C#注釋標記說明: A.2.1 此標記提供一種機制以指示用特殊字體(如用于代碼塊的字體)設置說明中的文本段落。對于實際代碼行,請使用 (第 A.2.2 節)。 語法:text 示例:
A.2.2 標記用于將一行或多行源代碼或程序輸出設置為某種特殊字體。對于敘述中較小的代碼段,請使用 (第 A.2.1 節)。 語法:
示例:
A.2.3 此標記用于在注釋中插入代碼示例,以說明如何使用所關聯的方法或其他庫成員。通常,此標記是同標記 (第 A.2.2 節)一起使用的。 語法:description 示例: 有關示例,請參見 (第 A.2.2 節)。 A.2.4 此標記提供一種方法以說明關聯的方法可能引發的異常。 語法:description 其中cref="member" 成員的名稱。文檔生成器檢查給定成員是否存在,并將 member 轉換為文檔文件中的規范元素名稱。description 對引發異常的情況的描述。 示例:
A.2.5 此標記允許包含來自源代碼文件外部的 XML 文檔的信息。外部文件必須是符合標準格式的 XML 文檔,還可以將 XPath 表達式應用于該文檔來指定應包含該 XML 文檔中的哪些 XML 文本。然后用從外部文檔中選定的 XML 來替換 標記。 語法: filename" path="xpath" / 其中file="filename" 外部 XML 文件的文件名。該文件名是相對于包含 include 標記的文件進行解釋的(確定其完整路徑名)。 path="xpath" XPath 表達式,用于選擇外部 XML 文件中的某些 XML。 示例: 如果源代碼包含了如下聲明:
并且外部文件“docs.xml”含有以下內容:
這樣輸出的文檔就與源代碼中包含以下內容時一樣:
A.2.6 此標記用于創建列表或項目表。它可以包含 塊以定義表或定義列表的標頭行。(定義表時,僅需要在標頭中為 term 提供一個項。) 列表中的每一項都用一個 塊來描述。創建定義列表時,必須同時指定 term 和 description。但是,對于表、項目符號列表或編號列表,僅需要指定 description。 語法:
…
其中 term 要定義的術語,其定義位于 description 中。 description 是項目符號列表或編號列表中的項,或者是 term 的定義。 示例:
A.2.7. 此標記用于其他標記內,如 (第 A.2.11 節)或 (第 A.2.12 節),用于將結構添加到文本中。 語法: content 其中 content 段落文本。 示例:
A.2.8 該標記用于描述方法、構造函數或索引器的參數。 語法:description 其中name參數名。description參數的描述。 示例:
A.2.9 該標記表示某單詞是一個參數。這樣,生成文檔文件后經適當處理,可以用某種獨特的方法來格式化該參數。 語法: name 其中 name 參數名。 示例:
A.2.10 該標記用于將成員的安全性和可訪問性記入文檔。 語法: description 其中 cref="member" 成員的名稱。文檔生成器檢查給定的代碼元素是否存在,并將 member 轉換為文檔文件中的規范化元素名稱。 description 對成員的訪問屬性的說明。 示例:
A.2.11 該標記用于指定類型的概述信息。(使用 (第 A.2.15 節)描述類型的成員。) 語法 description 其中 description 摘要文本。 示例:
A.2.12 該標記用于描述方法的返回值。 語法: description 其中 description 返回值的說明。 示例:
A.2.13 該標記用于在文本內指定鏈接。使用 (第 A.2.14 節)指示將在“請參見”部分中出現的 文本。 語法: member"/ 其中 cref="member" 成員的名稱。文檔生成器檢查給定的代碼元素是否存在,并將 member 更改為所生成的文檔文件中的元素名稱。 示例:
A.2.14 該標記用于生成將列入“請參見”部分的項。使用 (第 A.2.13 節)指定來自文本內的鏈接。 語法: member"/ 其中 cref="member" 成員的名稱。文檔生成器檢查給定的代碼元素是否存在,并將 member 更改為所生成的文檔文件中的元素名稱。 示例:
A.2.15 可以用此標記描述類型的成員。使用 (第 A.2.11 節)描述類型本身。 語法: description 其中 description 關于成員的摘要描述。 示例:
A.2.16 該標記用于描述屬性。 語法: property description 其中 property description 屬性的說明。 示例:
A.3. 處理文檔文件 文檔生成器為源代碼中每個附加了“文檔注釋標記”的代碼元素生成一個 ID 字符串。該 ID 字符串唯一地標識源元素。文檔查看器利用此 ID 字符串來標識該文檔所描述的對應的元數據/反射項。 文檔文件不是源代碼的層次化表現形式;而是為每個元素生成的 ID 字符串的一維列表。 A.3.1. ID 字符串格式 文檔生成器在生成 ID 字符串時遵循下列規則: 不在字符串中放置空白。 字符串的第一部分通過單個字符后跟一個冒號來標識被標識成員的種類。定義以下幾種成員: 字符串的第二部分是元素的完全限定名,從命名空間的根開始。元素的名稱、包含著它的類型和命名空間都以句點分隔。如果項名本身含有句點,則將用 # (U+0023) 字符替換。(這里假定所有元素名中都沒有“# (U+0023)”字符。) 對于帶有參數的方法和屬性,接著是用括號括起來的參數列表。對于那些不帶參數的方法和屬性,則省略括號。多個參數以逗號分隔。每個參數的編碼都與 CLI 簽名相同,如下所示:參數由其完全限定名來表示。例如,int 變成 System.Int32、string 變成 System.String、object 變成 System.Object 等。具有 out 或 ref 修飾符的參數在其類型名后跟有 @ 符。對于由值傳遞或通過 params 傳遞的參數沒有特殊表示法。數組參數表示為 [ lowerbound : size , … , lowerbound : size ],其中逗號數量等于秩減去一,而下限和每個維的大小(如果已知)用十進制數表示。如果未指定下限或大小,它將被省略。如果省略了某個特定維的下限及大小,則“:”也將被省略。交錯數組由每個級別一個“[]”來表示。指針類型為非 void 的參數用類型名后面跟一個 *的形式來表示。void 指針用類型名 System.Void 表示。 A.3.2. ID 字符串示例 下列各個示例分別演示一段 C# 代碼以及為每個可以含有文檔注釋的源元素生成的 ID 字符串: 類型用它們的完全限定名來表示。
字段用它們的完全限定名來表示。
構造函數。
析構函數。
方法。
"M:Acme.ValueType.M(System.Int32)" "M:Acme.Widget.NestedClass.M(System.Int32)" "M:Acme.Widget.M0" "M:Acme.Widget.M1(System.Char,System.Single@,Acme.ValueType@)" "M:Acme.Widget.M2(System.Int16[],System.Int32[0:,0:],System.Int64[][])" "M:Acme.Widget.M3(System.Int64[][],Acme.Widget[0:,0:,0:][])" "M:Acme.Widget.M4(System.Char*,Color**)" "M:Acme.Widget.M5(System.Void*,System.Double*[0:,0:][])" "M:Acme.Widget.M6(System.Int32,System.Object[])" 屬性和索引器。
"P:Acme.Widget.Width" "P:Acme.Widget.Item(System.Int32)" "P:Acme.Widget.Item(System.String,System.Int32)" 事件。
"E:Acme.Widget.AnEvent" 一元運算符。
下面列出可使用的一元運算符函數名稱的完整集合:op_UnaryPlus、op_UnaryNegation、op_LogicalNot、op_OnesComplement、op_Increment、op_Decrement、op_True 和 op_False。 二元運算符。
下面列出可使用的二元運算符函數名稱的完整集合:op_Addition、op_Subtraction、op_Multiply、op_Division、op_Modulus、op_BitwiseAnd、op_BitwiseOr、op_ExclusiveOr、op_LeftShift、op_RightShift、op_Equality、op_Inequality、op_LessThan、op_LessThanOrEqual、op_GreaterThan 和 op_GreaterThanOrEqual。 轉換運算符具有一個尾隨“~”,然后再跟返回類型。
好了,以上就是關于Sandcastle的使用,相信大家以后都可以用得上,同時也給自己留作備忘。
該文章在 2024/2/7 22:10:45 編輯過 |
關鍵字查詢
相關文章
正在查詢... |