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);
}
相关推荐
xhxxx8 小时前
AI打字机的秘密:一个 buffer 如何让机器学会“慢慢说话”
前端·vue.js·openai
韩曙亮8 小时前
【Web APIs】BOM 浏览器对象模型 ⑥ ( location 对象 | location 常用属性和方法 | URL 简介 )
前端·javascript·dom·url·bom·location·浏览器对象模型
用户21411832636028 小时前
CC-Switch配置切换神器:5秒搞定多设备同步,坚果云让配置永不丢失
前端
勤奋的懒洋洋3509 小时前
前端实现多个图片打包下载
前端
豐儀麟阁贵9 小时前
9.5格式化字符串
java·开发语言·前端·面试
春生野草9 小时前
Ruoyi前端基于vue的脚手架的目录解析
前端·javascript·vue.js
m0_740043739 小时前
Axios拦截器 -- 请求拦截器和响应拦截器
开发语言·前端·javascript
不会代码的小猴10 小时前
C++的第十一天笔记
java·前端·jvm
风止何安啊10 小时前
递归 VS 动态规划:从 “无限套娃计算器” 到 “积木式解题神器”
前端·javascript·算法
ohyeah10 小时前
使用 Vue 3 实现大模型流式输出:从零搭建一个简易对话 Demo
前端·vue.js·openai