当前位置: 首页 > news >正文

[rust] rust学习

rust学习

1. 项目组织结构

工程

# 创建一个工程
cargo new my-project

工作空间

Rust 中,工作空间(Workspace) 是一个包含多个 Rust 项目的共享环境,用于管理多个 crate(库或可执行文件)。它允许多个 Rust 项目共享 Cargo.lock、依赖项和 target/ 目录,提高编译效率,并且适用于多包管理、模块化开发


🔹 为什么使用 Rust 工作空间?

Rust 工作空间适用于以下场景:

  1. 管理多个相关的 crate(类似于 monorepo)

    • 比如,你有一个主程序 app,但 app 依赖于 lib1lib2,可以用工作空间管理它们。
  2. 共享依赖,减少重复构建,提高编译速度。

    • 例如 applib1 都依赖 serde,Rust 只会编译一次。
  3. 统一管理 Cargo.lock,保证所有 crate 依赖版本一致。


🔹 如何创建 Rust 工作空间?

1️⃣ 创建一个 Rust 项目

mkdir my_workspace
cd my_workspace
cargo new --lib lib1
cargo new --lib lib2
cargo new --bin app

你会得到如下目录结构:

my_workspace/
├── Cargo.toml  # 工作空间的根 Cargo.toml
├── lib1/
│   ├── Cargo.toml
│   ├── src/
│   │   └── lib.rs
├── lib2/
│   ├── Cargo.toml
│   ├── src/
│   │   └── lib.rs
├── app/
│   ├── Cargo.toml
│   ├── src/
│   │   └── main.rs

2️⃣ 配置 Cargo.toml

my_workspace/Cargo.toml(根目录)中添加:

[workspace]
members = ["lib1", "lib2", "app"]
resolver = "2" # 使用 Cargo v2 依赖解析

这样,Rust 知道这 3 个项目属于同一个工作空间。


3️⃣ 在 app 依赖 lib1lib2

修改 app/Cargo.toml

[dependencies]
lib1 = { path = "../lib1" }
lib2 = { path = "../lib2" }

app/src/main.rs

use lib1::hello;
use lib2::world;

fn main() {
    hello();
    world();
}

lib1/src/lib.rs

pub fn hello() {
    println!("Hello from lib1!");
}

lib2/src/lib.rs

pub fn world() {
    println!("World from lib2!");
}

4️⃣ 运行工作空间

你可以在 my_workspace/ 目录下直接运行:

cargo run -p app

输出:

Hello from lib1!
World from lib2!

你也可以一次性编译所有 crate

cargo build

🔹 工作空间的额外功能

✔ 共享 Cargo.lock

所有 crate 共享 Cargo.lock,保证相同的依赖版本:

my_workspace/
├── Cargo.lock  # 统一管理所有 crate 的依赖
├── ...

✔ 使用 workspace.dependencies

如果多个 crate 需要相同的依赖项,可以在根 Cargo.toml 统一声明:

[workspace.dependencies]
serde = "1.0"

然后,在 lib1/Cargo.tomllib2/Cargo.toml 这样写:

[dependencies]
serde = { workspace = true }

这样可以确保 lib1lib2 使用相同版本的 serde,避免版本冲突。


🔹 总结

Rust 工作空间 适用于管理多个 crate,优点包括:

  • 提高编译效率(共享 target/
  • 统一依赖管理(共享 Cargo.lockworkspace.dependencies
  • 模块化开发(适合 Monorepo)

适用于:

  • 大型项目(微服务、多组件)
  • 库+CLI 工具
  • 框架开发(如 Web 框架)

你有具体的 Rust 项目需求吗?我可以帮你优化工作空间结构! 🚀

2. 常使用的库

  • serde = { version = “1.0”, features = [“derive”] } # 序列化支持
  • serde_json = “1.0” # JSON 序列化
  • tokio = { version = “1.35”, features = [“full”] }
  • axum = “0.7.9”

相关文章:

  • 【C语言系列】字符函数和字符串函数
  • QT:串口上位机
  • 电脑神器,轻松超越系统自带!
  • 【免费】2006-2020年各省单位GDP能耗增速数据
  • 每日学习之一万个为什么
  • MySQL的 where 1=1会不会影响性能?
  • Stable Diffusion/DALL-E 3图像生成优化策略
  • Linux:自动化构建-make/Makefile
  • 软件开发项目有哪些风险
  • Redis Sentinel (哨兵模式)深度解析:构建高可用分布式缓存系统的核心机制
  • 【大模型学习】第十七章 预训练技术综述
  • [翱捷]功能机 Wifi
  • Pygame实现射击鸭子游戏3-2
  • 根据 GPU 型号安装指定 CUDA 版本的详细步骤(附有CUDA版本对应torch版本的表格)
  • 策略模式和责任链模式的区别
  • C语言刷题第五章(下)
  • 道路运输安全员考试备考:循序渐进,稳步提升
  • 手机遥控开关技术解析与应用指南
  • 【随手笔记】中移4G记录(ML307R)
  • AutoGen学习笔记系列(十二)Advanced - Memory
  • 受美关税影响,本田预计新财年净利下降七成,并推迟加拿大建厂计划
  • 来伊份发布关于消费者反映蜜枣粽问题处理的情况说明:与消费者达成和解
  • 俄土外长通话讨论俄乌谈判问题
  • 中美经贸高层会谈在日内瓦结束,中国代表团将举行发布会
  • 巴基斯坦称未违反停火协议
  • 瑞士联邦主席凯勒-祖特尔、联邦副主席帕姆兰会见何立峰