前言
学习rust的前提如下:
(1)先把Rust环境装好
(2)把VScode中关于Rust的插件装好
\;\\\;\\\;
目录
- 前言
- 先写一个程序看看
- Rust的基础
- mut可变变量
- let重定义覆盖变量
- 基本数据类型
- 复合类型()和 [ ]
- 数组
- 字符串&str
- 字符串String
- Rust的Misc
- if
- 循环while和loop和for
- 枚举与结构体
- match
- 所有权
先写一个程序看看
新建一个hello.rs文件
fn main(){println!("hola,mundo!");let a=12;println!("{} is {}","a",a);let b=1;println!("{0}={0},{1}={1}",a,b); //如果注释这行,那么b没有被使用,就会报错!(够安全吧)println!("{{}},}},{{"); //只有括号let _c=-2;let _=-3;
}
在VScode中的终端中编译hello.rs生成hello.pdb和hello.exe两个文件,然后再运行hello.exe文件。如果是在windows的console窗口中,就直接输入hello就行了。
注:如果单独输入{,}会出错!!!
没有使用的变量会报错,但是加个下划线做前缀(let _b=1;
),表示这个变量特殊处理,不使用也不会报错了!
\;\\\;\\\;
Rust的基础
mut可变变量
普通定义的变量(let a=1;
)默认是不可变的,所以不能再赋值(a=2;
)—— 改成可变的(let mut a=1;
)
fn main(){let mut a=1; a=2; //有警告,表示在打印之前被覆盖了!println!("a={}",a);
}
上面出现warning的原因也是因为变量没有使用,在赋值和定义之间,原本的(变量,值)没有被使用!
- 把变量a都改成_a就没有警告了!
\;\\\;
let重定义覆盖变量
fn main(){let a=1;let a=false;println!("a={}",a);
}
\;\\\;
基本数据类型
fn main(){let a:f32 = 3.14159;println!("a={}",a);let a:f64 = 3.14159;println!("a={}",a);let a:bool=true;println!("a={}",a);let a:i8 = 12;println!("a={}",a);let a:u8 = 0b0000_1101;println!("a={}",a);let a:i16 = 12;println!("a={}",a);let a:u16 = 0xd;println!("a={}",a);let a:i32 = 1_24;println!("a={}",a);let a:u32 = 0xd;println!("a={}",a);let a:i64 = 12;println!("a={}",a);let a:u64 = 0xd;println!("a={}",a);let a:i128 = 12;println!("a={}",a);let a:u128 = 0xd;println!("a={}",a);let a:isize = 12;println!("a={}",a);let a:usize = 0xd;println!("a={}",a);
}
\;\\\;
复合类型()和 [ ]
类型转换用as i64
这种形式
复合类型的使用可以用 .0 .1 .2
这种形式
fn main(){let x0=12u32;let x1=89;let x2=x0;let a:(i64,i64,i64) = (x0 as i64,x1,x2 as i64); //复合类型let (y0,mut y1,y2)=a;y1=-1;println!("y0={},y1={},y2={}",a.0,a.1,a.2);
}
\;\\\;
数组
fn main(){let a:[i64;6]=[0,1,2,3,4,5];println!("first={},last={}",a[0],a[a.len()-1]);
}
\;\\\;
字符串&str
Rust字符串类似C语言中的指针
这里的&str不是String,那个是结构体,变量是私有的,只能通过接口去使用它。
简单来说&str是固定长度的数组,而String是动态数组!
fn main(){let a: &str = "hello,word";let a="hola,mundo";let b: &str = a;println!("{}",b);
}
fn main() {let a:&str = "Dog";let b:String = "Cat".to_string();say(a);say(&b); //传递引用println!("a={}",a);println!("&a={}",&a);println!("b={}",b);println!("&b={}",&b);
}fn say(name: &str) {println!("Hello, {}!", name);
}
\;\\\;
字符串String
fn main() {let a = String::from("i think of you a lot");let b = a.replace("you","the one"); //前面的替换成后面的println!("a={}",a);println!("b={}",b);
}
\;\\\;\\\;
Rust的Misc
if
fn main(){let a=100;let mut b=0;//b钳制在0到62之间if a<0{b=0;}else if a<50{b+=a;}else if a<75{b=50 + (a-50)/2;}else{b=62;}let c = if b>50 { 1} else {-1};println!("a={},b={},c={}",a,b,c);
}
\;\\\;
循环while和loop和for
fn main(){let mut a=100;while a<0 {a-=1;}loop{let mut b=a;if b==100{break;}b+=1;}for i in -1..10 {a+=i;}println!("a={}",a);
}
\;\\\;
枚举与结构体
使用 #[derive()] 属性时,Rust 编译器会自动生成实现特定 traits 所需的代码,从而简化了手动编写这些代码的过程
#[derive(Debug)]
enum Person {Student,Teacher,Staff,
}#[derive(Debug)]
struct Master{Dog:i32,Fish:i32,Cat:i32,
}fn main() {let a = Person::Teacher;let b = Master{Dog:7,Fish:-7,Cat:0};println!("{:?}", a);println!("{:#?}",b);
}
match
#[derive(Debug)]
enum Coin {Penny,Nickel,Dime,Quarter,
}fn main() {let a = Coin::Dime;println!("{}",test(a));
}fn test(a : Coin)-> i64{match a{Coin::Penny => 1,Coin::Nickel => 5,Coin::Dime => 10,Coin::Quarter => 25,}
}
\;\\\;\\\;
所有权
let a=1;
let b=a;
基本数据赋值时,标识符的值会被拷贝一份。
let a = String::from("hello");
let b = a;
字符串赋值时,标识符的值被拷贝,但是实际的字符串还是同一个。因为字符串多了一层,它的标识符的值只是实际字符串的地址而已!
let b = a.clone(); //这样才能真的拷贝一份
\;\\\;
fn main(){let mut a=1;println!("[main]a={}",a);test(&mut a);println!("[main]a={}",a);
}
fn test(a:&mut i64){ //传入地址*a=2; //数据被修改了println!("[test]a={}",a);
}
fn main(){let a=String::from("hola");println!("[main]a={}",a);test(&a);println!("[main]a={}",a);
}
fn test(a:&String){ println!("[test]a={}",a);
}
\;\\\;\\\;