您现在的位置: 首页 资讯 > > 正文
Rust - 安装环境、基本类型、流程控制、函数、模块、泛型、所有权 当前热点
发布时间:2023-02-26 22:05:13 来源:腾讯云

安装环境、基本类型

学习Rust语言是公司同事最先开始提议的,准备用接下来的项目试试水,Rust是一个强类型编译型语言,比较偏向底层,所以开启了Rust的探索之旅。

环境准备阶段

安装Rust环境

安装命令:

curl --proto "=https" --tlsv1.2 -sSf https://sh.rustup.rs | shsource $HOME/.cargo/env //设置环境变量rustc --version //查看安装版本

Cargo

Cargo 是 Rust 的构建系统和包管理器。Rust 开发者常用 Cargo 来管理 Rust 工程和获取工程所依赖的库。


(资料图片仅供参考)

Cargo 就是Vue里面的npm,php里的composer。

cargo run [项目名称]cargo build 

生成的目录结构如下:

.|-- Cargo.lock|-- Cargo.toml|-- src|   `-- main.rs`-- target    |-- CACHEDIR.TAG    `-- debug        |-- build        |-- deps        |   |-- stark-2c1445affc8ccd97        |   `-- stark-2c1445affc8ccd97.d        |-- examples        |-- incremental        |-- stark        `-- stark.d

数据类型概述

类型是对二进制数据的一种约束行为。类型比起二进制数据,有许多优势:

减少开发者心智负担安全、容易优化

常见的类型分类:

静态类型:在编译器对类型进行检查动态类型:在运行期对类型进行检查强类型:不允许隐式类型转换弱类型:允许隐式类型转换

Rust是强类型语言。

Rust基本数据类型

1.Rust的变量

创建变量使用let关键字变量默认是不可变的,关键字前面加mut转换为可变变量常量使用const关键字定义隐藏属性

2.基础数据类型

Rust是一门静态编程语言,所有变量的类型必须在编译期就被明确规定。

整数:Rust有12种不同类型的整数

对于未明确标明的类型的整数,Rust默认采用i32isize和usize根据系统不同而有不同的长度

长度

有符号

无符号

8-bit

i8

u8

16-bit

i16

u16

32-bit

i32

u32

64-bit

i64

u64

128-bit

i128

u128

128-bit

i128

u128

arch

isize

usize

fn main() {    let number :i8 = 32;    println!("{}",number);}

浮点数型: Rust 与其它语言一样支持 32 位浮点数(f32)和 64 位浮点数(f64)。默认情况下,64.0 将表示 64 位浮点数,因为现代计算机处理器对两种浮点数计算的速度几乎相同,但 64 位浮点数精度更高。

fn main() {    let x = 2.0; // f64    let y: f32 = 3.0; // f32}

布尔值:布尔型用 bool 表示,值只能为 true 或 false。大小为一个字节。

fn main() {    let t = true;    let f: bool = false;}

字符型:字符型用 char 表示。Rust的 char 类型大小为 4 个字节,代表 Unicode标量值,这意味着它可以支持中文,日文和韩文字符等非英文字符甚至表情符号和零宽度空格在 Rust 中都是有效的 char 值。

注意: Rust 中字符串和字符都必须使用 UTF-8 编码,否则编译器会报错。

复合类型

元组

元组用一对 ( ) 包括的一组数据,可以包含不同种类的数据:

fn main() {    let a: i32= 10;    let b = "A";    //创建一个元组    let mytuple:(i32,char) = (a,b);    // 从元组中读取一个值    println!("{},{}",mytuple.0,mytuple.1);    //解封装    let(c , d) = mytuple;    println!(" {} , {} ",c , d);}

数组

数组用一对 包括的同类型数据。Rust语法规定,每个数组的类型必须相同。Rust的数组中不同于其他一些语言中的数组,具有固定长度。

数组下标以0开始,同时Rust存在越界检查。

fn main() {    //初始化数组    let myarray: [u32;5] = [1,2,3,4,5];    println!("myarray[1] = {}",myarray[1]);    //数组越界    //let index = "5".parse::().unwrap();    //println!("myarray[5]={}",myarray[index]);    let mut mybuffer: [u32;32 * 1024] = [10;32*1024];    println!("mybuffer[1024] = {}", mybuffer[1024]);    //修改数组的值    mybuffer[1024] = 13;    println!("mybuffer[1024] = {}", mybuffer[1024]);}

切片

切片(Slice)是对数据值的部分引用。切片这个名字往往出现在生物课上,我们做样本玻片的时候要从生物体上获取切片,以供在显微镜上观察。

fn main() {    //切片可以切数组    let myarray: [u32;5] = [1,2,3,4,5];    let slice = &myarray[0..3];    println!("slice[0] = {}, slice.length = {} ",slice[0],slice.len());    //切片还可以切字符串        let s = String::from("broadcast");    let part1 = &s[0..5];    let part2 = &s[5..9];    println!("{}={}+{}", s, part1, part2);}

Slice没有自己去存储数据,截取的都是引用数据。

结构体

结构体是多种不同数据类型的组合。它与元组类似,但区别在于我们可以为每个成员命名,可以使用struct关键字三种类型的结构。

元组结构经典的C结构无字段的单元结构

结构体使用驼峰命名。

//元组结构struct Pair(i32,f32);//经典的C结构struct Peison {    name:String,    age:u8}fn main() { let pair = Pair(10,4.2); let person = Peison{     name: String::from("stark"),     age:32 }; println!("pair.0 = {}",pair.0); println!("person.name = {}, person.age = {}",person.name,person.age);}

引用派生属性,打印结构体。

#[derive(Debug)]struct Peison {    name:String,    age:u8}fn main() { let person = Peison {     name: String::from("stark"),     age:32 }; println!("{:?}",person);}

枚举

枚举类在 Rust 中并不像其他编程语言中的概念那样简单,但依然可以十分简单的使用:

#[derive(Debug)]enum IPAddr {    IPv4(u8,u8,u8,u8),    IPv6(u8,u8,u8,u8,u8,u8,u8,u8,u8,u8,u8,u8),}fn main() {    let localhost :IPAddr = IPAddr::IPv4(127,0,0,1);    match localhost {        IPAddr::IPv4(a,b,c,d) => {            println!("{},{},{},{}",a,b,c,d);        }        _ => {}    }}

Rust - 流程控制、函数

if else

Rust的if的布尔条件不用括号括起来。if所有分支返回的类型必须相同。

fn main() {    let number = 3;    if number < 5 {        println!("条件为 true");    } else {        println!("条件为 false");    }}

loop、while

Rust提供了loop一个关键字来表示无限循环。while是根据条件进行循环。

fn main() {    let s = ["R", "U", "N", "O", "O", "B"];    let mut i = 0;    loop {        let ch = s[i];        if ch == "O" {            break;        }        println!("\"{}\"", ch);        i += 1;    }}

for range

Rust的 for in 语法可以用来遍历一个迭代器,有多种方法可以创建一个迭代器,最简单也是最常见的方式:

a..b:这里将创建一个a,但不包含b的,步长为1的迭代器a..=b:这里将创建一个a,且包含b的,步长为1的迭代器
fn main() {    for i in 0..5 {        println!("i value is {}",i);    }        println!("-------------");        for i in 0..=5 {        println!("i value is {}",i);    }}

for in 语法第二个重要的使用场景是遍历数组,但这首先将数组转化为一个迭代器,可以通过.iter()或者.iter_mut实现,区别是在于后者是可变的。

fn main() {    let mut myarray = [1,2,3];    for i in myarray.iter(){        println!("i value is {} ",i);    }    for  i in myarray.iter_mut() {        *i *= 2;    }    for i in myarray.iter(){        println!("i value is {} ",i);    }}

遍历关联数组:

fn main() {    let myarray = ["a","b","c"];    for i in myarray.iter(){        println!("i value is {} ",i);    }}

match / if_let / while_let

在Rust 中 没有 switch 语句,matcher 就是 switch 的一个变形,但比其他语言中的 switch 更强大!

let x = 5;match x {    1 => println!("one"),    2 => println!("two"),    3 => println!("three"),    4 => println!("four"),    5 => println!("five"),    _ => println!("something else"),}

函数与方法

函数

函数定义以fn为关键字,它的参数是带类型注释的,就像变量一样,如果函数返回值,则必须在箭头->之后指定返回类型。

fn sum_number(n:u64) -> u64 {    if n < 2 {        n    }else{        n+1    }}fn main() {    println!("sumNumber is {}",sum_number(10))}

函数与闭包

Rust的闭包是一种匿名函数,它可以从它的上下文中捕获变量的值,闭包使用 ||-> 语法定义,闭包可以保存在变量中。

fn main() {    let time3 = |n:u32| -> u32 { n * 3 };    println!("time3 is {}",time3(10));}

move关键字可以从闭包环境中捕获值,它最常用的场景是将主线程中的一个变量传递到了子线程中。

use std::thread;fn main() {    let hi = "hi,stark";    thread::spawn(move || {        println!("stark value {}",hi);    }).join();}

高阶函数 / 发散函数

在数学和计算机科学里,高阶函数至少满足一个条件的函数:

接收一个或多个函数作为输入输出一个函数

在数学中它们叫做算子或泛函,高阶函数是函数式编程中一个重要概念。

fn action(method:fn(u32,u32)->u32,a: u32,b: u32) -> u32 {    method(a,b);}fn add(a:u32,b:u32) ->  u32 {    a + b }fn sub(a:u32,b:u32) ->  u32 {    a - b }fn main() {  println!("{}",action(add,10,20))}

发散函数

发散函数指的是永远不会被返回,它们的返回值标记!,这是一个空类型。

Rust - 使用模块、泛型、所有权

Rust项目的代码组织包含以下三个基本概念:

Package(包)Crate(箱)Module(模块)

Package

Package 用于管理一个或多个Crate,创建一个Package的方式是使用cargo new stark命令:

[root@b0b5a9371ce4 stark]# tree.├── Cargo.toml└── src    └── main.rs1 directory, 2 files

Create

Create是Rust最小单元,既Rust是编译器是以Create为最小单元进行编译的。Create在一个范围内将相关的功能组合在一起,并最终通过编译器生成一个库文件或者是二进制文件。

Module

Module允许我们将一个Create中的代码组织成独立的代码块,以便增强可读性和代码复用,同时Module还控制代码的可见性,将代码分为公开和私有两种属性,定义一个模块的关键字是mod

Module的可见性

Rust中的模块内部的代码、结构体、函数默认是私有的,但是可以通过pub关键字来改变他们的可见性,通过选择性的对外可见性来隐藏模块内部的实现细节。

比较常见的三种pub写法:

pub 成员对模块可见pub(self) 成员对模块内的子模块可见pub(crate) 成员对整个crate可见
mod mod1 {    pub const MESSAGE :&str = "Hello,world";}fn main() {  println!("{}",mod1::MESSAGE)}

Module的引入

在文件开头使用mod 文件路径;,第二种可以映射到一个文件夹,但文件夹中要存在mod.rs,该文件夹可作为一个模块。

结构体的可见性

结构体的字段和方法默认是私有的,通过加上pub修饰语可使得结构体中的字段和方法可以在定义结构体外访问。要注意,与结构体同一个模块和代码的访问结构体中的字段和方法并不要求该字段是可见的。

use 绑定模块成员

使用use绑定类库,as可以指定别名。

使用super与self简化模块路径

除了使用完整路径访问模块内成员,还可以使用super与self关键字相对路径对模块进行访问。

super :上层模块self : 当前模块

泛型

Rust中未指定参数类型的概念叫泛型。

函数参数的泛型

pub fn sum_number>(a:T,b:T) -> T {    return a+b;}

结构体中的泛型

struct Point {    x:T,    y:T}struct Line {    x: Point,    y: Point}fn main() {  println!("{}",cc::MESSAGE);  println!("{}",cc::sum_number(10,20));  let pointx = Point{x:0,y:0};  let pointy = Point{x:10,y:10};  let line = Line {x:pointx, y:pointy};  println!("{},{},{}",line.x.x,line.x.y,line.y.x);}

Rust内存管理

所有权是Rust这门语言的核心概念,Rust最以为豪的内存安全就建立在所有权之上。

Rust采用了一种中间的方案RALL,它兼具GC的易用性和安全性,同时又有极高的性能。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5MlOioAW-1649511656829)(https://note.youdao.com/yws/res/17856/WEBRESOURCE1759d05270a5a0ada71aa6cc869b2c73)

rust所有权

Rust中每个值都绑定有一个变量,称为该值的所有者。每个值只有一个所有者,而且每个值都有它的作用域。一但当这个值离开作用域,这个值占用的内存将被回收。
fn main() {    let s2:String;    {        let s1 = String::from("Hello,world");        s2 = s1;        //println!("s1 value {}",s1);        //value borrowed here after move    }    println!("s2 value {}",s2);}

借用

在有些时候,我们希望使用一个值而不拥有这个值,这种需求在函数调用的时候特别常见。

fn echo(s:String){    println!("{}",s);}fn main() {    let s = String::from("hello.world");    echo(s);    println!("{}",s);}

Rust一个变量只有一个所有权。

fn echo(s:&String){    println!("{}",s);}fn main() {    let s = String::from("hello.world");    echo(&s);    println!("{}",s);}

不可变引用与可变引用

默认情况下,引用是不可变的,如果希望修改引用的值,需要使用&mut

fn change(s: &mut String){    s.push_str("chenged!")}fn main() {    // 要借用的变量s也需要是可变的变量    let mut s = String::from("hello.world");    change(&mut s);    println!("{}",s);}

同一时间内,至多有一个可变引用。

fn main() {    let mut s = String::from("hello.world");    let s1_ref = &mut s;    let s2_ref = &mut s;    println!("{}",s1_ref);    println!("{}",s2_ref);}

生命周期注解

生命周期注解不会改变之前生命周期的长短,它还是原来的生命周期,注解是给编译器看的,拥有相同的生命周期注解,生命周期都是一样的。

fn bigger (str1:&str,str2:&str) -> &str {    if str1 > str2 {        str1    }else{        str2    }}fn main() {    println!("{}",bigger("a","b"));}

结构体当中的生命周期注释

#[derive(Debug)]struct Person {    name: String}fn main() {   let p = Person{ name:String::from("zhangyu") };   println!("{:?}",p );}

标签: Rust 编程算法 Java

新兴食品现身市场 “植物肉”产品能否“俘获”消费者的胃?

最近一段时间,部分超市和电商平台售卖的植物肉纷纷推出促销优惠活动,销量看涨。不过也有消费者表示,...

绍兴招才引智云对话活动举行 诚邀天下英才“会盟”绍兴

懂人才是大学问,聚人才是大本事,用人才是大智慧。近年来,绍兴市大力实施人才强市战略,持续深化人才...

江苏省自然资源厅出台指导意见 推进老旧小区改造工作

省自然资源厅近日出台《关于大力推进城镇老旧小区改造工作的指导意见》,针对城镇老旧小区改造中规划和...

2021年中国心血管健康指数排名:江苏位列前五

进行了排名,江苏位列前五。北京、上海、江苏等地居民心血管更健康这项发表在《中国疾病预防控制中心周...

科研人员揭示5种豆科植物的核型数据及亲缘关系

近日,四川农业大学林学院副教授罗小梅团队在遗传学领域期刊《基因》(Genes),在线发表了题为《基于5S ...

“烟火气”十足的“江苏味道” 河西CBD顶流商圈开街迎客

开街啦!5月18日上午,在河西CBD金融城融媒路上,2022江苏省新能源汽车&信息消费创新产品推广系列活动启...

首个锌金属的伴侣蛋白诞生 有助于解决缺锌公共卫生问题

据17日发表在《细胞》与《细胞报告》杂志上的两篇论文,美国研究人员发现了第一个锌金属的伴侣蛋白,并...

科学家首次揭示糖尿病卵母细胞起源 有助于减少生育缺陷

5月19日,记者从浙江大学获悉,浙大医学院附属妇产科医院黄荷凤院士团队与中国科学院徐国良院士团队合作...

前4月河北省电信网络诈骗案件发案数连续4个月同比下降

记者从省政府新闻办5月18日举行的河北省打击治理电信网络诈骗犯罪工作新闻发布会上获悉,今年1至4月,全...

重庆:到2025年25个重点领域企业能效全部达到基准水平

3月18日,重庆日报记者从市发展改革委获悉,日前,市发展改革委、市经济信息委、市生态环境局、市市场监...

重磅!2021“发现重庆之美”获奖名单揭晓

3月19日,2021发现重庆之美颁奖典礼在线上举行,最美城市管理人、最美坡坎崖、最美街头绿地、垃圾分类时...

去年重庆回收废弃农膜1.4万吨 农膜回收率达89.31%

3月16日,市五届人大常委会第六十九次主任会议听取了市政府关于《重庆市人大常委会对市人民政府农业面源...

申报分两批!今年国家级博士后科研工作站新设站工作启动

3月19日,重庆日报记者从市人力社保局获悉,为推动产学研深度融合,加强博士后工作平台建设,我市将开展...

浙江鄞州:“水、电、气、数”通办专窗实现城乡公共服务均等化

近日,在宁波市鄞州区邱隘镇公共事务服务中心,66岁的邱隘镇沈家新村居民邱秀月在一个窗口相继办理了不...

打开“浙里办” 浙江1000家农贸市场农产品可线上比价

今天哪个菜场的五花肉最便宜?食品安全抽检结果怎么样?这些问题,浙江居民只需打开浙里办APP上的浙里市场...

浙江鉴湖国家湿地公园规划发布 打造乡村数字旅游

19日上午,鉴湖国家湿地公园规划发布暨东鉴湖农旅观光体验启动仪式在绍兴市越城区陶堰街道举行。当天,...

总投资超10亿元!6个石化装备运维项目在岱山签约

日前,总投资超10亿元的6个石化装备运维项目在岱山经济开发区集中签约。此次签约的项目占地106亩,规划...

如何避免成为“买而不做”的“装备党”祝 杰

自恋是人的天性,人们总是希望自己是更好的,那么自己拥有的事物,也就相应地被自我赋予了更高的价值,...

山西临汾:率先在全省建起农村集体经济开发区

3月17日,临汾市农村集体经济发展(集团)有限公司在临汾经济开发区揭牌。以此为标志,临汾率先在全省建起...

一线工作近22年的缉毒警:我知道坏的是毒品不是人性

  “影子”般的缉毒警:一线工作22年,我知道坏的是毒品不是人性  如果我不继续干,别人也要干,缉...

广东肇庆“毒驾连撞5车致1死”肇事司机被批捕

  1月5日14时30分许,广东肇庆市端州区一男子赵某毒驾连撞5车,致一人死亡。  1月10日,澎湃新闻(ww...

江西最大文物倒卖案宣判:倒卖国家二级文物 9人获刑

  中新网南昌1月10日电 (冷峥嵘 张一怡)江西省共青城市人民法院10日发布消息称,近日,该院依法审结...

青海保障门源地震后生活必需品应急物资

  中新网西宁1月10日电 (记者 孙睿)记者10日从青海省商务厅获悉,青海海北州门源县6 9级地震灾害发...

广西东兴口岸恢复通关 入境需网上预约

  中新社防城港1月10日电 (翟李强)自2022年1月10日零时起,广西东兴口岸和边民互市贸易区恢复人员、...

呼和浩特:寒假期间有条件的学校要开展校内托管服务

  中新网呼和浩特1月10日电 (记者 张林虎)10日,记者从呼和浩特市教育局获悉,在暑假校内托管试点的...

“中国最后一个原始部落”翁丁老寨火灾原因公布

北京市十五届人大五次会议胜利闭幕

天津市委市政府致全市父老乡亲的慰问信:我们一定能够打赢

天津米面油存量由20天提高至30天 超市菜市场进货量翻倍

兰州名师话“美育”:“尚乐立人”分层培优 以“美”润教

子夜直击,天津寒天战“疫”

重庆姐弟被生父扔下坠亡案上诉期结束 一审法院暂未收到两被告人上诉状

天津:划定封控区 全市开展全员核酸检测

江歌母亲江秋莲:尊重法院判决,法律认定在我意料之中

中国边疆“北方第一所”:9名民警守护“生命禁区”

辟谣!网传“封控区管控区相继解封”通知并非西安

河南安阳9日12时至24时新增11例本土确诊病例

老人5折环卫工8折生活困难免费 这家面馆背后有个暖心事

铁路公安以110幅优秀书画作品庆祝人民警察节

本周中东部冷空气频繁 东北等地有降雪

河南新增本土确诊病例60例

“打拐”民警眼里的百态人生:见证一份份不愿放弃的爱

迎腊八北京晴天上线 阵风6至7级体感冻人

多省份倡议春节“非必要不离开”,这地补贴1000元

伪造国家机关证件典型案例发布 有力打击制假贩假行为

15年照顾170多个新生儿 金牌月嫂“漂”到海外去看娃

江歌母亲江秋莲诉刘鑫案一审将于今日宣判

河南省安阳市两地划为高风险地区 一地划为中风险地区

员工迟到一次罚一千引争议 单位惩戒员工法律边界何在?

以体育人 秀出“青年范儿”

保安、厨师曾被竞业限制 企业滥用竞业限制让员工很苦恼

反诈老陈破圈:人民群众在哪 就把反诈宣传开展到哪

一所中职学校的育人实践

各地严惩恶意欠薪 保障农民工及时拿到工资

中学生成剧本杀行业潜在消费人群 多方助推行业“净化”

“这就是我最好的选择”

对餐饮浪费说“不”(百姓关注)

校园“直通车” 服务“零距离”

琉璃河遗址 两段铭文共证北京三千年建城史

千元修复个人征信报告?银行:“征信修复”都是骗局

琉璃河遗址 两段铭文共证北京三千年建城史

北京公交将开展无人驾驶道路测试

河南郑州调整五地为中风险区域 公路入郑需核酸检测阴性证明

“共享法庭”让金融消费者畅享“智慧司法”便利

《传奇2》网游著作权纠纷案峰回路转 最高法五份裁决四份改判一份发回重审

三代警察:从未放弃的28年

“胡叔叔”的寻亲工作室

天津津南本轮本土疫情第3—20例阳性感染者活动轨迹公布

“团圆”行动刑侦专家吕游 每一个案例都有单独的技术方案

河南“战疫”直面五重考验

开考古书店日均两三个顾客 流量时代她决心仍是只卖书

冬奥开幕在即 “双减”催热冰雪课堂

“不得以任何借口拒收患者”彰显生命至上

天津多站进京车票暂停发售

冷空气来袭广州气温骤降 广东多地发布寒冷预警

x 广告
x 广告

Copyright ©  2015-2022 华南自然网版权所有  备案号:粤ICP备18025786号-52   联系邮箱: 954 29 18 82 @qq.com