07_函数

1. 函数的声明

声明函数使用fn关键字,依照惯例,针对函数名和变量名,Rust使用snake case 命名规范,即所有字母都是小写,单词之间使用下划线分开。如下

rust 复制代码
fn main() {
    println!("Hello, world!");
    annother_function();
}

fn annother_function() {
    println!("Another function.");
}

2. 函数的参数

parameters是我们在定义函数时的参数,叫形参;arguments是我们在调用函数时的实际参数,叫实参。在函数的签名里,必须声明每个参数的类型,如下

rust 复制代码
fn main() {
    println!("Hello, world!");
    annother_function(5, 6); // arugment is 5 and 6
}

fn annother_function(x: i32, y: i32) {
    // parameter is x and y
    println!("the value of x is: {}", x);
    println!("the value of y is: {}", y);
}

3. 函数中的语句(statement)与表达式(expression)

函数有一系列的语句组成,可选的可以由一个表达式结束。

  • 语句是执行一些动作的指令,函数的定义也是语句,语句不返回值,所以不可以使用let将一个语句赋给一个变量。
  • rust是一个基于表达式的语言,表达式会执行计算并产生一个值。

示例:

rust 复制代码
fn main() {
    let x = 5;
}

以上代码中,main函数的整体也是语句。其中let x = 5;是一条语句 ,该部分的右边是一个表达式,该表达式的值就是5,如果我们把该行改为let x = 5 + 6;,那么表达式就是5 + 6。表达式可以作为语句的一部分,调用函数是表达式,调用println!宏也是表达式。

3. 函数的返回值

->符号后面声明函数返回值的类型,但是不可以为返回值命名。

在rust里,通常返回值就是函数体里面最后一个表达式的值。如果想提前返回,需使用return关键字,并指定一个值,大多数函数默认使用最后一个表达式作为返回值。如下例子:

rust 复制代码
fn plus_five(x: i32) -> i32 {
    x + 5
}

fn main() {
    let x = plus_five(6);
    println!("The value of x is: {}", x);
}

在上面代码中,five函数的最后一个表达式值是x = 5,所以x + 5是该函数的返回结果。

注意的是x + 5后不能加;,加分号就不是表达式了,返回的是tuple,而不是i32

4. 函数的注释

函数可以使用单行注释或者多行注释的方式,单行注释符号为//,多行注释以/*开头,以*/结尾,如下示例

rust 复制代码
// 这是单行注释
fn plus_five(x: i32) -> i32 {
    x + 5
}

/**
 * 这是多行注释
 */
fn main() {
    let x = plus_five(6);
    println!("The value of x is: {}", x);
}
相关推荐
jump_jump3 小时前
基于 Squoosh WASM 的浏览器端图片转换库
前端·javascript·性能优化
小二·6 小时前
前端监控体系完全指南:从错误捕获到用户行为分析(Vue 3 + Sentry + Web Vitals)
前端·vue.js·sentry
阿珊和她的猫7 小时前
`require` 与 `import` 的区别剖析
前端·webpack
谎言西西里7 小时前
零基础 Coze + 前端 Vue3 边玩边开发:宠物冰球运动员生成器
前端·coze
努力的小郑8 小时前
2025年度总结:当我在 Cursor 里敲下 Tab 的那一刻,我知道时代变了
前端·后端·ai编程
GIS之路8 小时前
GDAL 实现数据空间查询
前端
OEC小胖胖8 小时前
01|从 Monorepo 到发布产物:React 仓库全景与构建链路
前端·react.js·前端框架
2501_944711438 小时前
构建 React Todo 应用:组件通信与状态管理的最佳实践
前端·javascript·react.js
困惑阿三9 小时前
2025 前端技术全景图:从“夯”到“拉”排行榜
前端·javascript·程序人生·react.js·vue·学习方法
苏瞳儿9 小时前
vue2与vue3的区别
前端·javascript·vue.js