十分钟 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()
}

本文完,感谢阅读

相关推荐
工边页字几秒前
LLM 系统设计核心:为什么必须压缩上下文?有哪些工程策略
前端·人工智能·后端
嚣张丶小麦兜9 分钟前
react的理解
前端·react.js·前端框架
重庆穿山甲13 分钟前
身份证照片自动裁剪(OpenCV 四边形检测 + 透视矫正)
前端·后端
跟着珅聪学java13 分钟前
Electron + Vue 现代化“新品展示“和“快捷下单“菜单
开发语言·前端·javascript
何贤13 分钟前
用 Three.js 写了一个《我的世界》,结果老外差点给我众筹做游戏?
前端·开源·three.js
踩着两条虫31 分钟前
AI 驱动的 Vue3 应用开发平台 深入探究(七):双向代码转换之 Vue源码到DSL解析
前端·vue.js·ai编程
专业流量卡32 分钟前
用ai去看源码
前端·react.js
踩着两条虫34 分钟前
AI 驱动的 Vue3 应用开发平台 深入探究(六):双向代码转换之DSL到Vue代码生成
前端·vue.js·ai编程
Wect34 分钟前
React 中的双缓存 Fiber 树机制
前端·react.js·面试
天才熊猫君34 分钟前
Vue 3 中 Watch 的陷阱:为什么异步操作后创建的监听会泄漏?
前端·javascript