Rust 基础教程
Rust 编程语言教程
Rust是一门注重安全、并发和性能的系统编程语言。本文将从Rust的基本语法、常用功能到高级特性,详细介绍Rust的使用方法。
目录
- 简介
- 环境配置
- 基础语法
- 变量和常量
- 数据类型
- 函数
- 控制流
- 所有权和借用
- 所有权
- 借用
- 结构体和枚举
- 结构体
- 枚举
- 模块和包
- 错误处理
- 并发编程
- 常用库和工具
- 示例项目
简介
Rust是一门由Mozilla开发的系统编程语言,它的设计目标是提供内存安全、并发编程和高性能。Rust借鉴了许多现代编程语言的优点,同时引入了独特的所有权系统,以确保内存安全和线程安全。
环境配置
要开始使用Rust,首先需要安装Rust编译器和包管理工具Cargo。
安装Rust
可以通过Rust的官方安装工具 rustup 安装Rust。打开终端并运行以下命令:
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
安装完成后,可以通过以下命令检查Rust是否安装成功:
rustc --version
cargo --version
创建第一个Rust项目
使用Cargo创建一个新的Rust项目:
cargo new hello_rust
cd hello_rust
项目目录结构如下:
hello_rust
├── Cargo.toml
└── src└── main.rs
Cargo.toml 文件是项目的配置文件,main.rs 文件是项目的入口点。
基础语法
变量和常量
Rust中的变量默认是不可变的,可以使用 let 关键字声明变量,使用 mut 关键字声明可变变量。常量使用 const 关键字声明。
fn main() {let x = 5; // 不可变变量let mut y = 10; // 可变变量const PI: f64 = 3.14159; // 常量println!("x: {}, y: {}, PI: {}", x, y, PI);y = 15;println!("Updated y: {}", y);
}
数据类型
Rust具有多种基本数据类型,包括标量类型和复合类型。
fn main() {// 标量类型let int_var: i32 = 10; // 整数let float_var: f64 = 3.14; // 浮点数let bool_var: bool = true; // 布尔值let char_var: char = 'R'; // 字符// 复合类型let tuple_var: (i32, f64, char) = (10, 3.14, 'R'); // 元组let array_var: [i32; 3] = [1, 2, 3]; // 数组println!("int_var: {}, float_var: {}, bool_var: {}, char_var: {}", int_var, float_var, bool_var, char_var);println!("tuple_var: {:?}", tuple_var);println!("array_var: {:?}", array_var);
}
函数
函数是Rust中的基本代码单元,使用 fn 关键字定义。
fn main() {let result = add(5, 10);println!("Result: {}", result);
}fn add(a: i32, b: i32) -> i32 {a + b
}
控制流
Rust支持常见的控制流结构,如 if、loop、while 和 for。
fn main() {let number = 5;// if 表达式if number < 10 {println!("number is less than 10");} else {println!("number is 10 or greater");}// loop 循环let mut count = 0;loop {count += 1;if count == 3 {break;}}// while 循环while count < 5 {count += 1;}// for 循环for i in 0..5 {println!("i: {}", i);}
}
所有权和借用
所有权
Rust的所有权系统是其核心特性,确保内存安全。
fn main() {let s1 = String::from("hello");let s2 = s1; // s1的所有权被移动到s2// println!("{}", s1); // 这行代码将导致编译错误println!("{}", s2);
}
借用
借用可以让我们在不转移所有权的情况下使用变量。
fn main() {let s1 = String::from("hello");let len = calculate_length(&s1); // 借用s1println!("The length of '{}' is {}.", s1, len);
}fn calculate_length(s: &String) -> usize {s.len()
}
结构体和枚举
结构体
结构体用于定义复杂的数据类型。
struct User {username: String,email: String,sign_in_count: u64,active: bool,
}fn main() {let user1 = User {username: String::from("someone"),email: String::from("someone@example.com"),sign_in_count: 1,active: true,};println!("Username: {}", user1.username);
}
枚举
枚举用于定义一组可能的值。
enum Message {Quit,Move { x: i32, y: i32 },Write(String),ChangeColor(i32, i32, i32),
}fn main() {let msg = Message::Write(String::from("Hello"));match msg {Message::Quit => println!("Quit"),Message::Move { x, y } => println!("Move to ({}, {})", x, y),Message::Write(text) => println!("Text: {}", text),Message::ChangeColor(r, g, b) => println!("Change color to ({}, {}, {})", r, g, b),}
}
模块和包
模块和包用于组织代码。
mod network {pub fn connect() {println!("Network connected");}pub mod server {pub fn start() {println!("Server started");}}
}fn main() {network::connect();network::server::start();
}
错误处理
Rust使用 Result 和 Option 类型进行错误处理。
fn main() {let result = divide(4.0, 2.0);match result {Ok(v) => println!("Result: {}", v),Err(e) => println!("Error: {}", e),}
}fn divide(a: f64, b: f64) -> Result<f64, String> {if b == 0.0 {Err(String::from("Division by zero"))} else {Ok(a / b)}
}
并发编程
Rust通过线程和消息传递模型支持并发编程。
use std::thread;
use std::sync::mpsc;fn main() {let (tx, rx) = mpsc::channel();thread::spawn(move || {tx.send(String::from("Hello from thread")).unwrap();});let received = rx.recv().unwrap();println!("Received: {}", received);
}
常用库和工具
Rust生态系统中有许多常用库和工具,例如 serde 用于序列化和反序列化,tokio 用于异步编程。
serde
# Cargo.toml
[dependencies]
serde = { version = "1.0", features = ["derive"] }
serde_json = "1.0"
use serde::{Serialize, Deserialize};#[derive(Serialize, Deserialize)]
struct Person {name: String,age: u8,
}fn main() {let p = Person {name: String::from("Alice"),age: 30,};let json = serde_json::to_string(&p).unwrap();println!("JSON: {}", json);let p2: Person = serde_json::from_str(&json).unwrap();println!("Name: {}, Age: {}", p2.name, p2.age);
}
示例项目
最后,我们通过一个简单的示例项目来巩固学到的知识。
项目描述
创建一个命令行程序,它接受用户输入,并计算输入字符串的单词数量。
项目结构
word_count
├── Cargo.toml
└── src└── main.rs
代码实现
use std::env;
use std::fs;fn main() {let args: Vec<String> = env::args().collect();let filename = &args[1];let contents = fs::read_to_string(filename).expect("Something went wrong reading the file");let word_count = contents.split_whitespace().count();println!("The file '{}' contains {} words", filename, word_count);
}
运行项目
cargo run text.txt
以上就是Rust编程语言的详细教程,从基础语法到高级特性,希望对您学习Rust有所帮助。Rust是一门强大而高效的语言,掌握它将使您在系统编程和并发编程领域游刃有余。
相关文章:
Rust 基础教程
Rust 编程语言教程 Rust是一门注重安全、并发和性能的系统编程语言。本文将从Rust的基本语法、常用功能到高级特性,详细介绍Rust的使用方法。 目录 简介环境配置基础语法 变量和常量数据类型函数控制流 所有权和借用 所有权借用 结构体和枚举 结构体枚举 模块和包…...
Study--Oracle-06-Oracler网络管理
一、ORACLE的监听管理 1、ORACLE网络监听配置文件 cd /u01/app/oracle/product/12.2.0/db_1/network/admin 2、在Oracle数据库中,监听器(Listener)是一个独立的进程,它监听数据库服务器上的特定端口上的网络连接请求,…...
uniapp零基础入门Vue3组合式API语法版本开发咸虾米壁纸项目实战
嗨,大家好,我是爱搞知识的咸虾米。 今天给大家带来的是零基础入门uniapp,课程采用的是最新的Vue3组合式API版本,22年发布的uniappVue2版本获得了官方推荐,有很多同学等着我这个vue3版本的那,如果没有学过vu…...
数字信号处理教程(2)——时域离散信号与时域离散系统
上回书说到数字信号处理中基本的一个通用模型框架图。今天咱们继续,可以说今天要讲的东西必须是学习数字信号处理必备的观念——模拟与数字,连续和离散。 时域离散序列 由于数字信号基本都来自模拟信号,所以先来谈谈模拟信号。模拟信号就是…...
imx6ull/linux应用编程学习(8)PWM应用编程(基于正点)
1.应用层如何操控PWM: 与 LED 设备一样, PWM 同样也是通过 sysfs 方式进行操控,进入到/sys/class/pwm 目录下 这里列举出了 8 个以 pwmchipX(X 表示数字 0~7)命名的文件夹,这八个文件夹其实就对应了…...
等保2.0 实施方案
一、引言 随着信息技术的广泛应用,网络安全问题日益突出,为确保信息系统安全、稳定、可靠运行,保障国家安全、公共利益和个人信息安全,根据《网络安全法》及《信息安全技术 网络安全等级保护基本要求》(等保2.0&#x…...
7/3 第六周 数据库的高级查询
...
ubuntu20.04安装kazam桌面屏幕录制工具
在Ubuntu 20.04上安装Kazam可以通过以下步骤进行: 1.打开终端:可以通过按下Ctrl Alt T组合键来打开终端。 2.添加PPA源:Kazam不再在官方Ubuntu仓库中,但可以通过PPA源进行安装。在终端中输入以下命令来添加PPA: su…...
Python应对反爬虫的策略
Python应对反爬虫的策略 概述User-Agent 伪造应对302重定向IP限制与代理使用Cookies和Session管理动态内容加载数据加密与混淆请求频率限制爬虫检测算法法律与道德考量结语 概述 在数字化时代,网络数据采集已成为获取信息的重要手段之一。然而,随着技术…...
240703_昇思学习打卡-Day15-K近邻算法实现红酒聚类
KNN(K近邻)算法实现红酒聚类 K近邻算法,是有监督学习中的分类算法,可以用于分类和回归,本篇主要讲解其在分类上的用途。 文章目录 KNN(K近邻)算法实现红酒聚类算法原理数据下载数据读取与处理模型构建--计算距离模型预测 算法原理 KNN算法虽…...
keil5模拟 仿真 报错没有读写权限
debug*** error 65: access violation at 0x4002100C : no write permission 修改为: Dialog DLL默认是DCM3.DLL Parameter默认是-pCM3 应改为 Dialog DLL默认是DARMSTM.DLL Parameter默认是-pSTM32F103VE...
力扣爆刷第158天之TOP100五连刷56-60(子集、最小栈、最长有效括号)
力扣爆刷第158天之TOP100五连刷56-60(子集、最小栈、最长有效括号) 文章目录 力扣爆刷第158天之TOP100五连刷56-60(子集、最小栈、最长有效括号)一、78. 子集二、105. 从前序与中序遍历序列构造二叉树三、43. 字符串相乘四、155. …...
高薪程序员必修课-Java中 Synchronized锁的升级过程
目录 前言 锁的升级过程 1. 偏向锁(Biased Locking) 原理: 示例: 2. 轻量级锁(Lightweight Locking) 原理: 示例: 3. 重量级锁(Heavyweight Locking)…...
Vue项目打包上线
Nginx 是一个高性能的开源HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器。它在设计上旨在处理高并发的请求,是一个轻量级、高效能的Web服务器和反向代理服务器,广泛用于提供静态资源、负载均衡、反向代理等功能。 1、下载nginx 2、…...
算法题中常用的C++功能
文章目录 集合优先队列双端队列排序时自定义比较函数最大数值字符串追加:删除:子串: 元组vector查找创建和初始化赋值: 字典map引入头文件定义和初始化插入元素访问元素更新元素删除元素检查元素存在遍历元素int和string转换 集合…...
左扰动和右扰动
在SLAM(Simultaneous Localization and Mapping)中,使用左扰动还是右扰动主要取决于你如何定义坐标系和你希望扰动影响的姿态表示。这通常与你的坐标系选择和你正在解决的具体问题有关。 左扰动通常用于以下情况: 当你使用局部坐…...
【计算机网络】期末复习(2)
目录 第一章:概述 第二章:物理层 第三章:数据链路层 第四章:网络层 第五章:传输层 第一章:概述 三大类网络 (1)电信网络 (2)有线电视网络 ࿰…...
ojdbc8-full Oracle JDBC 驱动程序的一个完整发行版各文件的功能
文章目录 1. ojdbc8.jar2. ons.jar -3. oraclepki.jar -4. orai18n.jar -5. osdt_cert.jar -6. osdt_core.jar -7. ojdbc.policy -8. README.txt -9. simplefan.jar -10. ucp.jar -11. xdb.jar - ojdbc8-full 是 Oracle JDBC 驱动程序的一个完整发行版,包含了连接和…...
在Linux环境下使用sqlite3时,如果尝试对一个空表进行操作(例如插入数据),可能会遇到表被锁定的问题。
在Linux环境下使用sqlite3时,如果尝试对一个空表进行操作(例如插入数据),可能会遇到表被锁定的问题。这通常是因为sqlite3在默认情况下会对空表进行“延迟创建”,即在实际需要写入数据之前,表不会被真正创建…...
【目标检测】DINO
一、引言 论文: DINO: DETR with Improved DeNoising Anchor Boxes for End-to-End Object Detection 作者: IDEA 代码: DINO 注意: 该算法是在Deformable DETR、DAB-DETR、DN-DETR基础上的改进,在学习该算法前&#…...
【网络】每天掌握一个Linux命令 - iftop
在Linux系统中,iftop是网络管理的得力助手,能实时监控网络流量、连接情况等,帮助排查网络异常。接下来从多方面详细介绍它。 目录 【网络】每天掌握一个Linux命令 - iftop工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景…...
Java如何权衡是使用无序的数组还是有序的数组
在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...
【Java_EE】Spring MVC
目录 Spring Web MVC 编辑注解 RestController RequestMapping RequestParam RequestParam RequestBody PathVariable RequestPart 参数传递 注意事项 编辑参数重命名 RequestParam 编辑编辑传递集合 RequestParam 传递JSON数据 编辑RequestBody …...
USB Over IP专用硬件的5个特点
USB over IP技术通过将USB协议数据封装在标准TCP/IP网络数据包中,从根本上改变了USB连接。这允许客户端通过局域网或广域网远程访问和控制物理连接到服务器的USB设备(如专用硬件设备),从而消除了直接物理连接的需要。USB over IP的…...
基于Java Swing的电子通讯录设计与实现:附系统托盘功能代码详解
JAVASQL电子通讯录带系统托盘 一、系统概述 本电子通讯录系统采用Java Swing开发桌面应用,结合SQLite数据库实现联系人管理功能,并集成系统托盘功能提升用户体验。系统支持联系人的增删改查、分组管理、搜索过滤等功能,同时可以最小化到系统…...
C++:多态机制详解
目录 一. 多态的概念 1.静态多态(编译时多态) 二.动态多态的定义及实现 1.多态的构成条件 2.虚函数 3.虚函数的重写/覆盖 4.虚函数重写的一些其他问题 1).协变 2).析构函数的重写 5.override 和 final关键字 1&#…...
JS手写代码篇----使用Promise封装AJAX请求
15、使用Promise封装AJAX请求 promise就有reject和resolve了,就不必写成功和失败的回调函数了 const BASEURL ./手写ajax/test.jsonfunction promiseAjax() {return new Promise((resolve, reject) > {const xhr new XMLHttpRequest();xhr.open("get&quo…...
(一)单例模式
一、前言 单例模式属于六大创建型模式,即在软件设计过程中,主要关注创建对象的结果,并不关心创建对象的过程及细节。创建型设计模式将类对象的实例化过程进行抽象化接口设计,从而隐藏了类对象的实例是如何被创建的,封装了软件系统使用的具体对象类型。 六大创建型模式包括…...
nnUNet V2修改网络——暴力替换网络为UNet++
更换前,要用nnUNet V2跑通所用数据集,证明nnUNet V2、数据集、运行环境等没有问题 阅读nnU-Net V2 的 U-Net结构,初步了解要修改的网络,知己知彼,修改起来才能游刃有余。 U-Net存在两个局限,一是网络的最佳深度因应用场景而异,这取决于任务的难度和可用于训练的标注数…...
阿里云Ubuntu 22.04 64位搭建Flask流程(亲测)
cd /home 进入home盘 安装虚拟环境: 1、安装virtualenv pip install virtualenv 2.创建新的虚拟环境: virtualenv myenv 3、激活虚拟环境(激活环境可以在当前环境下安装包) source myenv/bin/activate 此时,终端…...
