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

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

注释