分享
 
 
 

C#文档自动化

王朝c#·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

C#文档自动化

本文主要参考《inside C#》第15章的内容。

熟悉java的程序员都知道,在java中有一种“文档注释”。采用这种注释之后,使用相应的命令,我们就可以得到与代码相关的文档说明。如今,在.net的世界中C#也提供了相同的功能。如果结合相应的工具,它还可以为我们产生漂亮的WEB风格的文档。

文档自动化初步:

在C#中文档注释对应的符号是:///。但光使用它还是不能为我们产生代码文档,还必须使用特殊的标记才行。这些标记实际上是XML标记,最常用的是< summary >。例如:

/// <summary>

/// A method with a string array param.

/// </summary>

public void Koo(string[] ss) {}

但是,并不是所有使用文档注释和这些标记的地方编译器都会为我们生成文档,它还会看这些标记是否与一些代码结构相关联。例如:

/// <summary>

/// 不产生这行

/// </summary>

就不产生任何文档。这些代码结构必须是:class, struct, enum, method, property, field, indexer, delegate, 或event.

产生文档的命令

- 命令行:csc /doc: ….xml …..cs;

- 如使用VS.net,则:项目 -> 属性 -> 配置属性 -> 生成 -> 输出 -> xml文档文件(在此填写文件名和路径);

- 如要生成web注释:工具 ->生成注释 web......。

输出文档的类型描述符

字符

描述

N

Namespace

T

类型:class, interface, struct, enum, delegate

F

Field

P

Property (包括indexers or other indexed properties)

M

Method (包括constructors和operators)

E

Event

!

Error:编译器无法解析这个元素。

一个输出的文件注释的示例:

<member name="F:SimpleXML.Class1.h">

<summary>

An enum field.

</summary>

</member>

<member name="T:SimpleXML.Class1.hType">

<summary>

An enum type.

</summary>

</member>

xml文档标记。

标记

描述

<c>

指示这行注释标识为Code

<code>

指示多行注释标识为Code

<example>

经常与<code>连用,用来给出如何使用某些成员的例子。

<exception>

指明一个成员会抛出哪些异常,经常与cref属性连用。

<include>

指明注释在哪些文件中,以及位置。

<list>

用来定义表头,经常与<item>连用

<newpara>

内部使用,如<remarks>或<returns>。让用户有机会给注释文本加入其他的结构。

<param>

说明参数的属性,编译器会检查参数的合法性。如果通不过,会在文档中产生!标识的警告。

<paramref>

类似<param>。

<permission>

标明用于成员的代码存取的安全性。

<remarks>

用于描述class或其它类型的描述性文字,不涉及具体细节(如果是这样,使用<summary>)。

<returns>

描述方法或函数的返回值。

<see>

指定一个链接。

<seealso>

指定要出现在See Also部分的文本。

<summary>

类型的描述性文字。它会被vs.net内置的IntelliSense使用并显示在对应的类型中。(即在vs.net中击键“.”出现的提示)

<value>

描述属性。

以上标记的属性。

标记

描述

cref

可用于任何标记来提供一个代码元素的参考。编译器将检查这个代码元素是否存在,如不存在则在文档中用!标识。

name

用于<param>或<paramref>

标记使用的例子

1. <param>标记

/// <summary>

/// A method with a string array param.

/// </summary>

/// <param name="ss"></param>

public void Koo(string[] ss) {}

2. <returns>标记

/// <summary>

/// A nonvoid method.

/// </summary>

/// <returns>The result of the operation.</returns>

public int Noo() { return 0; }

3. <exception>标记和cref 属性:

/// <summary>

/// <exception cref="System.Exception">

/// Throws a FileIOException when...

/// </exception>

/// </summary>

public void Foo() {}

4. <c>, <code>, 和<example>标记

/// <summary>

/// <c>Hoo</c> is a method in the <c>Class1</c> class.

/// </summary>

public void Hoo() {}

/// <summary>

/// The Joo method.

/// <example>This example shows how to use Joo:

/// <code>

/// <newpara/>

/// public static void Main()

/// {

/// Console.WriteLine(Class1.Joo());

/// }

/// <newpara/>

/// </code>

/// </example>

/// </summary>

public static int Joo() { return 0; }

5. <include> 标记

语法:

<include file='filename' path='tagpath[@name="id"]' />

/// <include file='supporting.xml' path='MyDocs/MyMembers[@name="Class1"]/*' />

class Class1{

public static void Main() {}

}

supporting.xml

<MyDocs>

<MyMembers name="Class1">

<summary>

The summary for this type.

</summary>

</MyMembers>

<MyMembers name="Class2">

<summary>

Another type description.

</summary>

</MyMembers>

</MyDocs>

6. <list>标记

语法:

<list type="bullet" │ "number" │ "table">

<listheader>

<term>term</term>

<description>description</description>

</listheader>

<item>

<term>term</term>

<description>description</description>

</item>

</list>

/// <remarks>Here is an example of a bulleted list:

/// <list type="bullet">

/// <item>

/// <description>Item 1.</description>

/// </item>

/// <item>

/// <description>Item 2.</description>

/// </item>

/// </list>

/// </remarks>

static void Main(string[] args) {}

扩充

由于产生的文档是XML文件,使得我们对它的处理非常方便。如可以定义一个xls来让它产生符合我们需要的文档,如HTML、WORD等等。对于HTML,C#的编译器有内置的支持。我们可以使用标准的HTML标记来扩充它。但由于XML是well-formed的,因此对于一些没有</…>符号的HTML元素则必须作为一个XML有效元素使用。如<br>,对应为<br/>。

总结

本文详细描述了C#文档自动化涉及的命令、标记和语法,并辅以例子说明。至于更详细的资料请查阅MSDN和有关的文档。由于本人英文水平有限,不当之处请多多包涵。呵呵。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有