3.4 注释

在Rust中,注释分为三类:

  • 代码注释,用于说明某一块代码功能,读者往往是同一项目的协作者;
  • 文档注释,支持markdown,对项目、公共API等进行描述,同时还能提供示例代码,读者是想要了解你项目的人;
  • 包和模块注释,文档注释的一种,用于说明当前包和模块的功能,方便用户迅速了解项目。

本节主要简单介绍代码注释和文档注释,对于注释的其它功能,我们后面再深入。

3.4.1 代码注释

代码注释有两种:

(1)行注释,使用//

(2)块注释,使用/* ... */

示例如下:

/* * 块注释: * 函数名:sum * 参数:a,b * 返回值类型:u32 */ fn sum(a: u32, b: u32) -> u32 { a + b } fn main() { let a: u32 = 1; let b: u32 = 1; // 行注释:调用sum函数计算a+b的和 let c = sum(a, b); println!("a + b is {:?}", c); }

3.4.2 文档注释

Rust提供了cargo doc命令可以把文档注释转换成html网页,最终展示给用户。文档注释也有文档行注释和文档块注释:

(1)文档行注释,使用///;

(2)文档块注释,使用/** ... */

示例如下:

// 下面是文档行注释 /// `add_one` 将指定值加1 /// /// # Examples /// /// ``` /// let arg = 5; /// let answer = my_crate::add_one(arg); /// /// assert_eq!(6, answer); /// ``` pub fn add_one(x: i32) -> i32 { x + 1 } // 下面是文档块注释 /** `add_two` 将指定值加2 \``` let arg = 5; let answer = my_crate::add_two(arg); assert_eq!(7, answer); \``` */ pub fn add_two(x: i32) -> i32 { x + 2 } fn main() { let a: i32 = 1; let c = add_one(a); println!("a + 1 is {:?}", c); let d = add_two(a); println!("a + 2 is {:?}", d); }

运行如下命令:

cargo doc --open

将打开上面代码里面文档注释生成的文档,如下图:

注释