十分钟 Rust 入门

前言

随着 Rust 在前端领域的使用越来越广,作为前端工程师有必要学习 Rust 这门语言了

变量赋值

rust 复制代码
// 不可变
let foo: i32 = 1;
// 可变
let mut bar: i32 = 1;

基础数据类型

整数

长度 有符号 无符号
8-bit i8 u8
16-bit i16 u16
32-bit i32 u32
64-bit i64 u64
128-bit i128 u128
arch isize usize

浮点数

rust 复制代码
// f32
let foo: f32 = 1.32;
// f64
let bar: f64 = 1.64;

布尔值

rust 复制代码
// bool
let foo = true;
let bar = false;

字符

rust 复制代码
// char
let char = 'a';

复合数据类型

字符串和切片

rust 复制代码
// String
let hello = String::from("Hello");
// slice
let a = &hello[1..5];

数组

rust 复制代码
// 长度固定
let arr: [i32; 5] = [1, 2, 3, 4, 5];

元组

rust 复制代码
// tuple
let tup: (i32, &str, f64) = (1, "a", 3.2);

枚举

rust 复制代码
enum Direction {
    Up,
    Down,
    Left,
    Right,
}

结构体

rust 复制代码
// struct
struct User {
    name: String,
    age: i32,
}

let user = User {
    name: String::from("mike"),
    age: 24,
};

集合类型

向量

rust 复制代码
// 长度可变
let vec: Vec<i32> = vec![1, 2, 3, 4, 5];

哈希表

rust 复制代码
use std::collections::HashMap;
// HashMap
let mut map: HashMap<&str, &str> = HashMap::new();
map.insert("foo", "bar");

模式匹配

rust 复制代码
let dir = Direction::Right;

match dir {
    Direction::Down => println!("down"),
    Direction::Left => println!("left"),
    _ => println!("other"),
}

分支语句

rust 复制代码
let a = 60;

if a > 50 {
    println!("大于 50");
} else if a < 50 {
    println!("小于 50");
} else {
    println!("等于 50");
}

循环语句

loop for while

rust 复制代码
let mut a = 100;

while a > 0 {
    a -= 1;
}

for v in 0..10 {
    println!("{}", v);
}

loop {
    println!("loop")
}

函数

rust 复制代码
fn hello(name: &str) {
    println!("Hello, {}", name);
}

fn main() {
    hello("John");
}

闭包

rust 复制代码
 let add_one = |x: u32| -> u32 { x + 1 };

模块

rust 复制代码
mod my_mod {
    pub fn hello() {
        println!("Hello");
    }
}

use my_mod::hello;

fn main() {
    hello()
}

本文完,感谢阅读

相关推荐
pas1362 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠2 小时前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6
珑墨3 小时前
【Turbo】使用介绍
前端
军军君013 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
打小就很皮...4 小时前
Tesseract.js OCR 中文识别
前端·react.js·ocr
wuhen_n5 小时前
JavaScript内存管理与执行上下文
前端·javascript
Hi_kenyon5 小时前
理解vue中的ref
前端·javascript·vue.js
大卫小东(Sheldon)6 小时前
GIM 2.0 发布:真正让 AI 提交消息可定制、可控、可项目级优化
git·rust·gim
落霞的思绪7 小时前
配置React和React-dom为CDN引入
前端·react.js·前端框架
Hacker_Z&Q7 小时前
CSS 笔记2 (属性)
前端·css·笔记