Rust 基础语法学习

Rust 基础语法学习

文章目录

  • Rust 基础语法学习
    • hello world
    • 变量
    • 数据类型
      • 整数类型
      • 进制表示方法
      • 浮点数类型
      • 布尔类型
      • 字符类型
      • 字符串
      • 复合类型
        • 元组
        • 结构体
        • 元组结构体
      • 切片类型
        • 字符串切片
        • 数组切片
    • 不可变变量与可变变量
    • 常量
    • 注释
    • 函数
      • 语句与表达式
    • 流程控制语句
      • if else条件判断
      • while循环
      • loop循环
      • for循环
      • if let 条件表达式
      • match-arm表达式

hello world

rust中的程序从main函数作为入口,hello rust!

fn main() {println!("hello world!");// println!是宏
}

变量

使用let关键字定义变量:

let k = 1;//定义整数变量 k

rust是强类型的,但声明是可以不写明类型,会自动推导类型。
如果要加入数据类型,也可以使用下面方式:

let k:i32 = 1;// k为i32类型整数

数据类型

整数类型

按照比特位长度和有无符号分类:

bit-lengthunsignedsigned
8u8i8
16u16i16
32u32i32
64u64i64
128u128i128
根据平台、架构决定usizeisize

这种类型命名方式非常直观,看到类型即可知道数据长度。

进制表示方法

十进制:12_345

16进制:0xff

八进制:0o77

二进制:0b1010_0101

使用下划线避免了数0的麻烦,非常直观。

浮点数类型

根据bit位数,分32位、64位浮点数,使用f32、f64表示。使用let声明浮点数,默认使用更高精度的f64。

let f = 1.0; //f64
let f:f32 = 1.0;// 声明 f32类型变量

布尔类型

使用bool关键字声明布尔变量,值为true或false。

let bl = true;
let bl = false;

字符类型

在 Rust 中,字符类型是 char。char 类型表示一个 Unicode 标量值(Unicode Scalar Value),它占用 4 个字节(32 位)。Unicode 标量值是 Unicode 编码中的第一个级别,它包括了符号、文字、数字、标点符号、控制符和其他字符等,涵盖了世界上大部分使用的语言和符号。

fn main() {let c1 = 'a';let c2 = 'α';let c3 = '😄';println!("char: {} {} {}", c1, c2, c3);
}

字符串

String 是一种可变的字符串类型,它可以动态地分配内存以容纳字符串数据,并且可以在运行时修改字符串内容。

创建字符串,如:

let mut my_string = String::new();//空字符串
let my_string = String::from("hello world");

复合类型

元组

在Rust中,允许将多个不同类型的值组合成一个单独的复合值,这种类型称为“元组”。

如:

let tuple_demo = ("1+1 =", 2, "is", true);

访问元组的方法:使用.x,x为元素索引。

println!("{} {} {} {}", tuple_demo.0, tuple_demo.1, tuple_demo.2, tuple_demo.3);

元组一旦定义就不能修改元素。

结构体

rust结构体定义:

struct 结构体名称{成员1: 成员1类型,成员2: 成员2类型,...
}

如定义一个student结构体,用于表述学生信息:

struct Student {name: String,//姓名id: u32,//学号age: u32//年龄
}

初始化

一般的初始化方法如下,使用key-value格式:

    let student = Student {name: String::from("zhangsan"),id: 001,age: 16  };

可以使用外部同名变量进行快速初始化:

fn main() {let name = String::from("lisi");let id:u32 = 001;let student = Student {name,id,age: 16  };println!("student info: {:?}", student);
}

也可以使用外部存在的同类型结构体变量,更新其余成员:

fn main() {let student = Student {name: String::from("xiaowang"),id: 001,age: 16   };let name = String::from("wangwu");let id = 002;let new_student = Student {name,//使用外部name、id变量初始化id,..student//其余部分使用student变量一次性初始化};println!("new_student info: {:?}", new_student);
}

元组结构体

元组结构体是一种没有具体字段名的结构体,它的字段只有类型而没有字段名。这使得它在表示简单的数据组合时非常有用。

struct Point2D(i32, i32);fn main() {let point = Point2D(10, 20);println!("X: {}, Y: {}", point.0, point.1);
}

切片类型

切片(slice)是对集合(数组、向量等)的连续部分进行引用的数据类型。它们允许以安全且高效的方式操作和访问集合的子集,而无需复制数据。

切片由两个主要部分组成:指向数据的指针和切片的长度。切片语法:

let slice: &[T] = &data[start..end];

字符串切片

直接上代码领悟:

fn main() {let str_demo = String::from("hello world");let str1 = &str_demo[..5]; /* 取0~4 */let str2 = &str_demo[6..11];/* 取6~10 */let str3 = &str_demo[6..];  /* 从第6个开始,取到最后一个 */let str4 = &str_demo[..];  /* 从头到尾 */println!("str1: {}, str2: {}, str3: {}, str4: {}", str1, str2, str3, str4);// str1: hello, str2: world, str3: world, str4: hello world
}

数组切片

fn main() {let array = [0, 1, 2, 3, 4, 5];let array_part1 = &array[0..1]; /* 0 */let array_part2 = &array[..3];  /* 0 1 2 */let array_part3 = &array[3..];  /* 3 4 5 */let array_all   = &array[..];   /* all */println!("  &array[0..1]= {:?},&array[..3] = {:?},&array[3..] = {:?},&array[..]  = {:?}", array_part1, array_part2, array_part3, array_all);/* output&array[0..1]= [0],&array[..3] = [0, 1, 2],&array[3..] = [3, 4, 5],&array[..]  = [0, 1, 2, 3, 4, 5]*/
}

不可变变量与可变变量

使用let单独声明的变量是不可变变量,声明后值无法修改。如果要声明一个值可以修改的变量,需要加入mut关键字,来表示变量可变的(mutable)。

fn main() {let a = 1;//a此后无法修改let mut b = 2;//b可以修改a = 2;//编译会出错b = 3;//mut变量是可变的
}

常量

使用const关键字声明常量,rust中要求常量必须使用全部大写字母表示,并使用下划线分割。否则会有编译警告。

const PI_VAL:f64 = 3.1415926;

注释

  • 代码注释:与C语言相同,使用//表示单行注释,/**/表示多行注释。
  • 文档注释,使用///在文档开头,使用这种注释方式,可以在导出程序说明文档更方便。
/// 将字符串转换成大写字母,并返回
/// 
/// # Examples
/// 
/// ```
/// let s = "hello world";
/// assert_eq!("HELLO WORLD", to_uppercase(s));
/// ```
fn to_uppercase(s: &str) -> String {s.to_uppercase()
}

函数

基本形式:

fn add2number(arg1: i32, arg2: i32) -> i32 {println!("{}+{} = {}", arg1, arg2, arg1+arg2);return arg1+arg2;
}

对于RUST,函数包含参数时,必须标明类型。

需要返回值时,使用 -> 在声明后表明返回值类型。

语句与表达式

rust函数由语句和表达式构成。

语句没有返回值,语句通常是执行某些操作、没有返回值的,如一些变量声明,如:

let a = 1;

表达式有计算步骤且有返回值,如:

a = 7
b + 2
c * (a + b)

通过表达式的返回值,可以直接传递到函数返回值,如:

fn add2number(arg1: i32, arg2: i32) -> i32 {println!("{}+{} = {}", arg1, arg2, arg1+arg2);arg1+arg2
}

arg1+arg2是一个表达式,它的返回值直接传递到函数返回值,不用再写return。

流程控制语句

if else条件判断

示例:

fn main() {let a = 3;if a > 2 {println!("a is greater than 2");} else if a < 2 {println!("a is less than 2");} else {println!("a is equal to 2");}
}

while循环

先判断再执行循环体代码:

fn main() {let mut count = 0;while count < 10 {count += 1;}println!("Count is {}", count);
}

loop循环

loop先执行函数体代码,在函数体中可以判断进行break 退出循环。

fn main() {let mut count = 0;loop {count += 1;if count > 10 {break;}}println!("Count is {}", count);
}

for循环

用于遍历或迭代某些集合类型数据。

fn main() {let arr: [i32; 5] = [1, 2, 3, 4, 5];// 遍历打印数组中的每个元素for num in &arr {println!("{}", num);}  
}

if let 条件表达式

有点像c中的三目运算符:

fn main() {let condition = true;let number = if condition { 5 } else { 6 };print!("The value of number is: {}", number);
}

match-arm表达式

match-arm用于匹配,与很多语言中的switch-case类似。

基本语法:

match <var> {type1 => { /*do-something*/ },type2 => { /*do-something*/ },...
}

所谓arm就是match表达式内的不同分支情况。

常用在枚举类型的匹配中,简单使用下:

enum Color{// 颜色枚举Red,/* 红色 */Green,/* 绿色 */Blue,/* 蓝色 */
}
fn main() {let ocean_color = Color::Blue;match ocean_color {Color::Blue => {/* 匹配蓝色 */println!("Ocean is blue");}_ => {/* 匹配其他 */println!("Special Ocean");}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/56823.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【ES6】—【新特性】—Symbol详情

一、一种新的原始数据类型 定义&#xff1a;独一无二的字符串 二、 声明方式 1. 无描述声明 let s1 Symbol() let s2 Symbol() console.log(s1, s2) // Symbol() Symbol() console.log(s1 s2) // falsePS: Symbol 声明的值是独一无二的 2. 有描述的声明 let s1 Symb…

sql顺序倒序查询

要根据 orderNum 字段的顺序查询&#xff0c;你可以使用 SQL 的 ORDER BY 子句。默认情况下&#xff0c;ORDER BY 是按升序排序的&#xff0c;但你可以使用 DESC 关键字来指定降序排序。 以下是一个示例查询&#xff0c;按照 orderNum 字段的顺序将结果返回&#xff1a; SELEC…

java八股文面试[java基础]——异常

自定义异常&#xff1a; 异常Exception 是指程序运行时&#xff0c; 由于输入错误、网络、程序逻辑等原因导致运行时出现的问题。出现异常时&#xff0c;程序会暂时中断执行&#xff0c;并根据产生异常的原因&#xff0c;创建对应异常类型的异常对象&#xff0c;并抛出给JVM捕…

Python中的 LOAD_DEREF LOAD_CLOSURE

LOAD_DEREF 在Python&#xff08;特别是CPython实现&#xff09;的字节码指令集中&#xff0c;LOAD_DEREF 是一个操作码&#xff0c;用于从函数的闭包&#xff08;如果存在&#xff09;或从当前函数的局部作用域外的命名空间&#xff08;enclosing scope&#xff09;中加载一个…

JavaScript-DOM查询

获取元素节点 获取元素节点的子节点 元素节点的属性 节点的修改 JavaScript中的DOM&#xff08;文档对象模型&#xff09;是一种编程接口&#xff0c;它允许JavaScript与HTML文档交互。创建DOM查询&#xff0c;可以使用多种方法. 获取元素节点 1. getElementById() – 通…

【C语言进阶(8)】自定义数据类型1:结构体

文章目录 前言Ⅰ 结构体的声明和定义⒈结构体声明⒉结构体定义⒊特殊的声明 Ⅱ 结构体的自引用Ⅲ 结构体初始化Ⅳ 访问结构体成员Ⅴ 结构体内存对齐⒈结构体内存对齐规则⒉分析结构体大小⒊嵌套结构体内存大小⒋内存对齐存在的原因 Ⅵ 修改默认对齐数Ⅶ 结构体传参 前言 C 语言…

js toFixed()方法的坑

最近发现JS当中toFixed()方法存在一些问题&#xff0c;采用原生的Number对象的原型对象上的toFixed()方法时&#xff0c;规则并不是所谓的“四舍五入”或者是“四舍六入五成双”&#xff0c;以谷歌浏览器为例: alert(1.5451.toFixed(2));//输出 1.55 alert(1.545.toFixed(2));…

围棋与育种

最近因为娃子报名了围棋课&#xff0c;我本着交一次课学两个人的态度&#xff0c;入门围棋&#xff0c;买了些书&#xff0c;听了些课&#xff0c;有所得。学了两个多月&#xff0c;现在6级水平&#xff0c;了解了基本的攻杀技巧&#xff0c;会判断输赢。 下面截图是今天的一盘…

Mr. Cappuccino的第64杯咖啡——Spring循环依赖问题

Spring循环依赖问题 什么是循环依赖问题示例项目结构项目代码运行结果 Async注解导致的问题使用Lazy注解解决Async注解导致的问题开启Aop使用代理对象示例项目结构项目代码运行结果 Spring是如何解决循环依赖问题的原理源码解读 什么情况下Spring无法解决循环依赖问题 什么是循…

IDEA配置热启动

1.背景 开发过程中&#xff0c;当写完一个功能我们需要运行应用程序测试&#xff0c;可能这个小功能中存在多个小bug&#xff0c;我们需要改正后重启服务器&#xff0c;这无形之中拖慢了开发的速度增加了开发时间&#xff0c;SpringBoot提供了spring-boot-devtools&#xff0c;…

MyBatis分页查询与特殊字符处理

目录 目录 一、引言 1.1 简介Mybatis 1.2分页查询的重要性 1.3MyBatis特殊字符处理的挑战 挑战1&#xff1a;SQL注入漏洞 挑战2&#xff1a;查询结果异常 挑战3&#xff1a;数据完整性问题 挑战4&#xff1a;跨平台兼容性 挑战5&#xff1a;用户体验 如何应对挑战 二…

Flask-Sockets和Flask-Login联合实现websocket的登录认证功能

flask_login 提供了一个方便的方式来管理用户会话。当你在 Flask 的 HTTP 视图中使用它时&#xff0c;你可以简单地使用 login_required 装饰器来确保用户已登录。 但是&#xff0c;flask_sockets 并没有直接与 flask_login 集成。如果你想在建立 WebSocket 连接时检查用户是否…

4.14 HTTPS 中 TLS 和 TCP 能同时握手吗?

目录 实现HTTPS中TLS和TCP同时握手的前提&#xff1a; 什么是TCP Fast Open&#xff1f; TLS v1.3 TCP Fast Open TLSv1.3 HTTPS都是基于TCP传输协议实现的&#xff0c;得先建立完可靠得TCP连接才能做TLS握手的事情。 实现HTTPS中TLS和TCP同时握手的前提&#xff1a; 1、…

uniapp国际化npm install vue-i18n报错

npm install vue-i18n //npmyarn add vue-i18n //yarn在vue2环境下&#xff0c;默认安装 npm install vue-i18n 的版本是 vue-i18n9.1.9&#xff0c;所以报错。 npm view vue-i18n versions --json 用以上命令查看版本&#xff1a; vue2建议5.0版本 npm install vue-i1…

nacos适配SqlServer、Oracle

继上文《nacos适配达梦、瀚高、人大金仓数据库及部分源码探究 》后补充nacos适配SqlServer、Oracle的贴码&#xff0c;主要区别是SqlServer、Oracle的分页SQL有点不一样&#xff0c;做个记录&#xff1b; SqlServer的分页有三种实现方式&#xff1a;offset /fetch next、利用ma…

JAVA-编程基础-10-集合

Lison <dreamlison163.com>, v1.0.0, 2023.04.23 JAVA-编程基础-10-集合 文章目录 JAVA-编程基础-10-集合List、Set、Map、队列全面解析ListArrayList创建ArrayList 向ArrayList中添加元素 List、Set、Map、队列全面解析 Java 集合框架可以分为两条大的支线&#xff1a;…

uniapp 项目实践总结(一)uniapp 框架知识总结

导语&#xff1a;最近开发了一个基于 uniapp 框架的项目&#xff0c;有一些感触和体会&#xff0c;所以想记录以下一些技术和经验&#xff0c;在这里做一个系列总结&#xff0c;算是对自己做一个交代吧。 目录 简介全局文件全局组件常用 API条件编译插件开发 简介 uniapp 是…

【C++】开源:Box2D动力学库配置与使用

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍Box2D动力学库配置与使用。 无专精则不能成&#xff0c;无涉猎则不能通。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&#xff0c…

Zenity 简介

什么使 Zenity Zenity 是一个开源的命令行工具&#xff0c;它提供了一种简单的方式来创建图形化的用户界面&#xff08;GUI&#xff09;对话框&#xff0c;以与用户进行交互。它基于 GTK 库&#xff0c;可以在 Linux 和其他 UNIX-like 系统上使用。 Zenity 可以通过命令行或脚…

Unity Alembic闪烁问题

最近在做项目时&#xff0c;发现Clo3D导出的服装abc动画&#xff0c;导入到Unity中后(已提前导入Alembic插件)&#xff0c;运行时屏幕会闪烁(变黑)。 经过几轮测试&#xff0c;发现是切线的问题。解决办法很简单。将abc文件上的Tangents属性值改为None即可。