环球速看:Rust - 安装环境、基本类型、流程控制、函数、模块、泛型、所有权
安装环境、基本类型
学习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 - 安装环境、基本类型、流程控制、函数、模块、泛型、所有权
- 完达山菁美奶粉怎么样 完达山奶粉怎么样_天天要闻
- 加雷斯洛克王国技能表_洛克王国泰西斯技能表 世界实时
- 汉马科技2月27日快速上涨
- 源见国际贸易 上海有限公司_关于源见国际贸易 上海有限公司介绍
- 以色列犹太定居者在约旦河西岸枪杀一名巴勒斯坦人
- 楼面价是什么意思_全球视点
- 天天快播:快停播吧!真丢人
- 世界速递!怎样养才能使仙人球出锦 养殖仙人球出锦的条件和方法介绍
- 每日快讯!世间定有轮回
- 【世界聚看点】橱柜台面选什么材质好_橱柜台面的材质选择
- 海西:精准发力 助企惠企产生跃升效应|天天新资讯
- 当前观点:打井机
- 油画棒也可以创作专业作品?13位油画名家进行了一次探索-环球热议
- 泄洪区 环球新视野
- 全国首个"零碳"樱花节登上厦门高山 白交祠第三届樱花节开幕
- 世界微动态丨哈兰德打进27粒英超进球,超阿圭罗成曼城单赛季英超进球最多球员
- 伊丽莎白妇产医院|环球短讯
- 【世界时快讯】被疯抢的“减肥神药”:假处方泛滥,黄牛高价兜售
- 微资讯!徐州二建培训,二级建造师考试,哪个专业更吃香(上元)
- 世界观热点:冬季恋歌
- 提升环卫设施 打造生态工程 头条焦点
- 张瑞芳
- 墟组词的组词
- 【速看料】报销医疗费多久到账
- 丽江苑小区 天天消息
- 全球新资讯:睡觉难以入睡有什么办法_睡觉难入睡怎么办
- wlk银色北伐军军需官在哪里_Wow那个银色北伐军坐骑 环球新要闻
- 济南力高君逸府新房刚交付 墙体出现多处空鼓开裂 环球微速讯
- 环球热讯:九年制义务教育三年级语文第一学期对应强化训练
- 职称入户广州需要居住证吗
- 【十周年】清洁人风采展——北京兆京保洁服务有限公司
- 环球报道:三合会档案
- 2023年云南省一季度重点水利工程龙泉水库等项目集中开工-环球新消息
- 当前资讯!q4是什么意思啊_q4是什么意思
- BLACKPINK世界巡回演唱会,5月将在成员LISA故乡泰国曼谷加场两天 天天热议
- 韩国输出的并不是文化,而是一种盈利模式的推广和附带品的出口
- 焦点要闻:B站为《三体》动画限免前十集
- 宝马116i报价及图片_宝马116i保险丝盒位置
- 校外参观胡师范学院图书馆_焦点快报
- 北京发布2023年供地计划 商品住宅用地与去年持平
- 俄安全局:拜登访乌时俄方未提供安全保障
- 热议:捷达汽车空调滤芯怎么换_捷达空调滤芯更换方法
- 焦点!美股开盘:三大指数高开,纳指涨0.67%,中概股多数上涨
- 袭人和宝玉有过几次婚姻_袭人和宝玉有过几次 实时焦点
- 世界实时:如何查询手机号码机主姓名
- 时讯:长电科技:公司旗下不同工厂与高通之间都有紧密合作
- 百度mp3
- 5本都市日常经营小说,精彩的世界和故事,都是难得一见的好书
- 劳务公司安全生产许可证在哪个部门办理_安全生产许可证在哪个部门办理 世界新消息
- 天天观察:葡语国家研究_葡语国家
- 焦点日报:硫化铵的化学式_硫化铵
- 最新:动漫壁纸(2)
- 重要进展!三澳核电二期工程环境影响报告书(选址阶段)获批
X 关闭
最新资讯
- 焦点快看:龙蟠科技:四川锂源拟将所持四川盈达19.09%股权转让给朗晟新能源
- 通讯!新车报讯:量产版本明年推出雷诺MeganeeVision官图发布
- 拉菲多少钱一瓶2020_拉菲多少钱一瓶
- 蛋白粉哪种品牌好_蛋白粉哪个牌子好-世界讯息
- 世界新资讯:日本航母数量_日本航母
- 静脉血栓吃什么药能好_静脉血栓吃什么药
- 全球快播:2月20日基金净值:富国均衡优选混合最新净值0.8286,涨1.48%
- 电脑屏幕变小了调大的具体步骤_电脑屏幕变小了怎么调大
- 全球看点:电脑如何安装音频设备程序_电脑如何安装音频设备
- 首开股份回复上交所:2022年预计计提存货跌价准备6亿-8亿元_世界今热点
- 学习劳动技能 体验劳动快乐——王稳庄镇中心小学寒假劳动实践主题活动
- 莱音珠宝铂金多少钱一克(2023年02月20日)参考价格_视焦点讯
- 2月20日盘前重要公司新闻
- 虾米能生吃吗 虾米可以生吃吗
- 环球今日讯!20家上市银行披露2022年业绩快报 经营效益大幅提升远超商业银行均值
- 淘宝、天猫描述加载中_天猫门店数据加载中
- 国家级区块链新型基础设施,“星火 链网”测试网开放 观速讯
- 全球快报:道家功法口诀_道教法术口诀
- 环球微速讯:花亚伟:守好“健康使者”初心 履行“仁心仁术”使命
- 三国全面战争武将收买规则_三国全面战争武将收买规则在哪 当前简讯
- 全球今日报丨笔记本的鼠标触摸板怎么打开_笔记本的鼠标触摸板怎么打开蓝牙
- 关于艺术品的作文600字 播报
- 淮阳区区长王献超带队调研棚改项目 环球热消息
- 授时历是谁制定的_授时历的作者
- 10首经典英文歌曲歌词_10首经典英文歌曲
- 热点!刘雨欣星跳水立方_关于刘雨欣星跳水立方的介绍
- 全球新资讯:履职故事|全国人大代表杨广奇:投身家乡建设 当好乡村振兴“带头人”
- 全球今热点:爱情公寓唐悠悠关谷黑脸结婚照-爱情公寓唐悠悠关谷
- 电流公式_电流公式
- 【热闻】thefaceshop金盏花_thefaceshop好用吗
- 02月17日从德宏出发到三亚的防疫政策 即时焦点
- 天创时尚: 股东减持计划时间届满暨减持结果公告|今日快看
- 天天通讯!两匹马的标志是什么车
- 资讯推荐:锡业股份:2月15日接受机构调研,中信建投、太平资产等多家机构参与
- 看热讯:学习爱眼护眼知识应成重要一课(服务窗)
- 事关教师编制、流动、弹性上下班等,成都四部门最新通知丨早读四川-天天百事通
- 99岁的芒格:投资中国更值得,比亚迪比特斯拉好
- 重生之官神_官神何常在
- 每日热讯!孙红雷电视剧全集黑帮_孙红雷黑帮电影
- 环球今头条!白玉兰开了 花期连续三年“抢跑”后近两年恢复正常
- 天天观热点:利德曼:副总裁丁耀良拟增持公司股份
- 小沈阳携老婆罕见露面,他打扮时髦似男团,沈春阳选错外套似保姆-环球聚焦
- 精选!女主穿越有暗势力_女主有势力的小说
- 征信花了信用卡就不能下卡了吗 天天消息
- 时讯:全市首个无人机网格化巡检示范区投运
- 最新:广誉远:融资净偿还531.09万元,融资余额8.5亿元(02-15)
- 全球看热讯:mp4/rm转换器_rm转mp4格式转换器
- 淘宝家居店铺名字大全 好听的家居店铺名字-环球播资讯
- 工商银行前6位数字-天天微动态
- 世界观点:做梦钓鱼钓到好大一条鱼
X 关闭