Rust cargo 命令行工具使用教程

简介

cargoRust 的构建系统和包管理器,负责创建项目、编译代码、管理依赖、运行测试等,是日常开发中最常用的工具。

创建项目

shell 复制代码
cargo new project_name      # 创建 binary 项目(可执行)
cargo new --lib mylib       # 创建 library 项目(供其它项目调用)

它会创建一个项目结构:

shell 复制代码
project_name/
├── Cargo.toml        # 项目信息和依赖配置
└── src/
    └── main.rs       # 项目主入口(lib.rs 对于库)

项目结构和配置文件

Cargo.toml 是项目的核心配置文件,类似于 Javapom.xmlNode.jspackage.json

toml 复制代码
[package]
name = "my_project"
version = "0.1.0"
edition = "2025"

[dependencies]
rand = "0.8"     # 添加依赖

常用命令

编译项目
shell 复制代码
cargo build          # 构建项目(debug 模式)
cargo build --release  # 构建 release 模式(优化)
运行项目
shell 复制代码
cargo run
带参数运行
shell 复制代码
cargo run -- arg1 arg2
检查语法和错误(不编译生成目标文件)
shell 复制代码
cargo check
添加依赖包
shell 复制代码
cargo add serde        # 需要安装 cargo-edit 插件

安装 cargo-edit

shell 复制代码
cargo install cargo-edit

依赖管理

在 Cargo.toml 中手动添加:
toml 复制代码
[dependencies]
serde = "1.0"
reqwest = { version = "0.11", features = ["json"] }
添加本地 crate:
toml 复制代码
[dependencies]
mycrate = { path = "../mycrate" }
添加 Git 仓库依赖:
toml 复制代码
[dependencies]
mycrate = { git = "https://github.com/user/mycrate.git" }

测试 & 文档

测试
shell 复制代码
cargo test
生成文档
shell 复制代码
cargo doc --open

发布 Crate 到 crates.io

shell 复制代码
cargo login                # 登录 crates.io(需要 token)
cargo publish              # 发布
cargo package              # 打包并检查

构建配置与工作区(workspace)

如果有多个 crate 项目组成一个工程:

根目录 Cargo.toml 配置:

toml 复制代码
[workspace]
members = [
    "core",
    "utils",
    "web"
]

常用 cargo 插件

shell 复制代码
cargo install cargo-edit         # 管理依赖(cargo add/remove/etc)
cargo install cargo-watch        # 自动监控并重编译
cargo install cargo-audit        # 审计安全问题
cargo install cargo-outdated     # 查看依赖是否过期

命令速查表

  • cargo new: 创建项目

  • cargo build:编译项目

  • cargo run:编译并运行

  • cargo check:检查代码是否可编译

  • cargo test:运行测试

  • cargo doc --open:生成并打开文档

  • cargo add xxx:添加依赖(需插件)

  • cargo update:更新依赖到最新版本

  • cargo clean:清理构建产物

  • cargo install:安装二进制 crate(如 ripgrep

相关推荐
自由随风飘1 小时前
python 题目练习1~5
开发语言·python
Bony-2 小时前
Go语言完全学习指南 - 从基础到精通------语言基础篇
服务器·开发语言·golang
天若有情6733 小时前
【java EE】IDEA 中创建或迁移 Spring 或 Java EE 项目的核心步骤和注意事项
后端·spring·java-ee·intellij-idea
fl1768313 小时前
基于python的天气预报系统设计和可视化数据分析源码+报告
开发语言·python·数据分析
ACP广源盛139246256734 小时前
(ACP广源盛)GSV6172---MIPI/LVDS 信号转换为 Type-C/DisplayPort 1.4/HDMI 2.0 并集成嵌入式 MCU
c语言·开发语言·单片机·嵌入式硬件·音视频
不穿格子的程序员4 小时前
从零开始刷算法-栈-括号匹配
java·开发语言·
雪域迷影4 小时前
C#中通过get请求获取api.open-meteo.com网站的天气数据
开发语言·http·c#·get
yue0084 小时前
C#类继承
java·开发语言·c#
Want5954 小时前
Python汤姆猫
开发语言·python
大鱼七成饱4 小时前
💥 从崩溃到稳定:我踩过的 Rust Tokio 线程池坑(含代码示例)
后端