Rust使用Cargo构建项目

article/2025/8/26 16:30:31

文章目录

  • 你好,Cargo!
    • 验证Cargo安装
    • 使用Cargo创建项目
      • 新建项目
      • 配置文件解析
      • 默认代码结构
    • Cargo工作流
      • 常用命令速查表
      • 详细使用说明
        • 1. 编译项目
        • 2. 运行程序
        • 3.快速检查
        • 4. 发布版本构建
    • Cargo的设计哲学
      • 约定优于配置
      • 工程化优势
    • 开发建议
      • 1. 新项目初始化​
      • 2. 现有项目迁移​
      • 3. 依赖管理实践
    • 总结

你好,Cargo!

Rust小蟹蟹

Cargo是Rust的构建系统和包管理器。绝大多数Rust开发者使用这个工具管理项目,因为它能自动化处理诸多任务:代码编译、依赖库下载、依赖构建等(代码所需的库文件称为​依赖​)。

即使是简单的"Hello, world!"项目(无依赖),使用Cargo也能获得规范的工程结构。随着项目复杂度提升,Cargo在依赖管理方面的优势将愈发明显。

验证Cargo安装

Cargo会随Rust官方安装包自动安装。验证是否安装成功:

$ cargo --version

若显示版本号(如cargo 1.86.0 (adf9b6ad1 2025-02-28))则表示安装正常。

使用Cargo创建项目

新建项目

在项目目录中执行:

$ cargo new hello_cargo

$ cd hello_cargo

该命令生成以下工程结构:

hello_cargo/├── Cargo.toml    # 项目配置文件└── src/└── main.rs   # 入口文件

同时自动初始化Git仓库(若当前不在Git仓库中),生成.gitignore文件。

提示:使用cargo new --vcs=git强制生成Git仓库,或–vcs=none跳过版本控制

配置文件解析

Cargo.toml​ 文件内容示例:

[package]
name = "hello_cargo"  # 项目名称
version = "0.1.0"     # 版本号
edition = "2024"      # Rust版本[dependencies]        # 依赖声明区
  • 使用TOML格式编写配置

  • edition字段指定Rust版本(详见附录E)

  • 依赖将在后续章节中添加

默认代码结构

自动生成的​src/main.rs​包含经典Hello World:

fn main() {println!("Hello, world!");}

Cargo强制约定源代码必须位于src目录,顶层目录存放配置文件、文档等非代码资源。

Cargo工作流

常用命令速查表

命令作用输出路径
cargo build编译调试版本target/debug/
cargo run编译并运行自动选择最新编译结果
cargo check快速语法检查(不生成二进制)
cargo build --release编译优化版本target/release/

详细使用说明

1. 编译项目
$ cargo build
  • 生成调试用可执行文件:target/debug/hello_cargo(Windows为.exe)

  • 首次编译生成Cargo.lock文件(自动跟踪依赖版本)

2. 运行程序
$ ./target/debug/hello_cargo  # 直接运行$ cargo run                   # 编译后自动运行
  • cargo run会智能判断是否需要重新编译
    运行效果如下图:
    运行效果
3.快速检查
$ cargo check
  • 检查编译错误但不生成二进制文件

  • 速度比完整编译快3-5倍,适合开发时实时验证

4. 发布版本构建

当项目需要部署时,使用优化编译:

$ cargo build --release
  • 生成的可执行文件位于target/release/

  • 启用编译器优化(运行更快,编译更慢)

  • 适合性能测试和最终发布

Cargo的设计哲学

约定优于配置

  • 强制源代码目录结构

  • 标准化配置文件格式

  • 跨平台命令一致性(Linux/macOS/Windows命令相同)

工程化优势

随着项目发展,Cargo的价值体现在:

依赖管理​:自动处理嵌套依赖

工作区支持​:管理多crate项目

构建缓存​:增量编译加速开发

元数据管理​:通过Cargo.toml声明项目属性

开发建议

1. 新项目初始化​

总是使用cargo new创建标准工程结构

2. 现有项目迁移​

手动创建src目录和Cargo.toml,或运行:

$ cargo init

3. 依赖管理实践

  • 添加依赖:直接编辑Cargo.toml的[dependencies]

  • 更新依赖:cargo update

  • 清除缓存:cargo clean

总结

  • Cargo核心功能:构建系统 + 包管理器

  • 使用cargo new创建规范项目

  • 通过build/run/check管理开发流程

  • 区分调试构建与发布构建

  • 理解Cargo的工程化设计理念


http://www.hkcw.cn/article/xOWlBbsHcS.shtml

相关文章

Python自动化之selenium语句——元素点击、输入、清空和八大元素定位方法

目录 一、元素定位配置 1.导包 2.查找元素 二、元素交互操作 1.点击 2.输入 3.清空 三、元素定位方法 1.ID 2.NAME 3.CLASS_NAME 4.TAG_NAME 5.LINK_TEXT 6.PARTIAL_LINK_TEXT 7.CSS_SELECTOR 8.XPATH 本节讲解元素定位相关知识 一、元素定位配置 1.导包 2.查…

C++并集查找

前言 C图论 C算法与数据结构 本博文代码打包下载 基本概念 并查集(Union-Find)是一种用于处理动态连通性(直接或间接相连)的数据结构,主要支持两种操作:union 和 find。通过这两个基本操作,可…

DeepSeek - 尝试一下GitHub Models中的DeepSeek

1.简单介绍 当前DeepSeek使用的人很多,各大AI平台中也快速引入了DeekSeek,比如Azure AI Foundary(以前名字是Azure AI Studio)中的Model Catalog, HuggingFace, GitHub Models等。同时也出现了一些支持DeepSeek的.NET类库。微软的Semantic Kernel也支持…

2025年人文发展与教育心理学国际会议(ICHDEP 2025)

2025年人文发展与教育心理学国际会议(ICHDEP 2025) 2025 International Conference on Humanistic Development and Educational Psychology 一、大会信息 会议简称:ICHDEP 2025 大会地点:中国广州 审稿通知:投稿后2…

实测,大模型谁更懂数据可视化?

大家好,我是 Ai 学习的老章 看论文时,经常看到漂亮的图表,很多不知道是用什么工具绘制的,或者很想复刻类似图表。 实测,大模型 LaTeX 公式识别,出乎预料 前文,我用 Kimi、Qwen-3-235B-A22B、…

MySQL高可用方案:Keepalived+双主库架构深度解析与实战指南

MySQL高可用方案:Keepalived+双主库架构深度解析与实战指南 一、方案概述 MySQL双主+Keepalived架构通过双节点互为主从模式结合VRRP协议,实现数据库服务的高可用与自动故障转移。该方案具备以下核心优势: 双活写入能力:两节点均可处理读写请求,通过双向复制保持数据强一…

【MySQL】联合查询(下)

目录 一. 子查询 单行子查询 多行子查询 多列子查询 在from子句中使用子查询 二. 合并查询 union all union 三.插入查询结果 上期我们讲了内连接、外连接、自连接查询,今天我们继续讲其他联合查询,没看过的之前的可以先去看看上期博客&#xff1…

unity—特效闪光衣服的设置

模型设置两个材质球,一个基础色,一个闪光色 闪光层设置 基础色设置

lvs-keepalived高可用群集

目录 1.Keepalived 概述及安装 1.1 Keepalived 的热备方式 1.2 keepalived的安装与服务控制 (1)安装keep alived (2)控制 Keepalived 服务DNF 安装 keepalived 后,执行以下命令将keepalived 服务设置为开机启动。 2.使用 Keepalived 实现双机热备 …

多端 API 兼容性设计:如何统一 iOS / Android / Web 接口规范?

在移动互联网时代,一个后台服务往往需要同时支撑 iOS、Android 和 Web 三端业务。当某电商App在Android端出现支付接口返回结构不一致导致崩溃,而iOS端却正常运行时;当某个Web端新功能因接口版本问题延期上线时——多端API的兼容性问题已成为…

Linux的SHELL脚本中的常用命令

一、设置主机名称 1.文件的方式 注:修改完毕文件后在当前的shell中是不生效的,如果需要看到效果,关闭当前shell后重新开启新的shell 2.通过命令更改主机名 注:hostnamectl hostname后加上你要改的主机名,即改即生效&…

ultraiso制作U盘镜像 针对win2012及win2016等需要特殊处理

1.按照正常操作步骤制作U盘镜像 以管理员方式运行软碟通2.正常制作镜像 3.由于磁盘格式,大于4G的文件是写不进去的 手动拷贝资源文件,右键将镜像挂载到电脑上 4.转换U盘格式 convert H:/fs:NTFS 执行该命令 此次需要保证U盘不被占用 这个时候就能存储…

【AI News | 20250529】每日AI进展

AI Repos 1、WebAgent 阿里巴巴通义实验室近日发布了WebDancer,一款旨在实现自主信息搜索的原生智能体搜索推理模型。WebDancer采用ReAct框架,通过分阶段训练范式,包括浏览数据构建、轨迹采样、监督微调和强化学习,赋予智能体自主…

【Python】3.函数与列表

文章目录 一、函数1、函数是什么?2、语法格式3、函数参数4、函数返回值5、变量作用域6、函数执行过程7、链式调用8、嵌套调用9、函数递归10、参数默认值11、关键字参数小结 二、列表和元组1、列表是什么,元组是什么?2、创建列表3、访问下标4、…

Arduino LCD 1602液晶显示器2(I2C总线)

LCD 1602液晶显示器2(I2C总线) 上一小节中我们学习了LCD1602的标准连接,但因为线太多,在实际的工作中会占用太多的Arduino的针脚,所以不是很实用。为了解决这个问题,下面我们介绍一种总线控制IIC&#xff0…

⚽【足球数据全维度解析】从基础统计到高阶分析,数据如何重塑现代足球?

足球世界正在经历一场深刻的数据革命。本文将系统介绍足球数据统计的完整体系,并揭示数据如何改变这项运动的训练、比赛和决策方式。 📊 一、核心数据统计维度 1. 比赛基础数据 射门数据:场均射门/射正(哈兰德5.2次/场&#xff0…

【C++项目】:仿 muduo 库 One-Thread-One-Loop 式并发服务器

🌈 个人主页:Zfox_ 🔥 系列专栏:C从入门到精通 目录 🔥 前言 一:🔥 项目储备知识 🦋 HTTP 服务器🦋 Reactor 模型🎀 单 Reactor 单线程:单I/O多路…

MaaS(模型即服务)是什么?

模型即服务(Model as a Service,MaaS)是近年来随着人工智能和云计算技术发展而兴起的一种服务模式。以下是对模型即服务的详细展开: 1.概念与定义 ​ ​模型即服务(MaaS)是一种将机器学习模型作为云服务…

AI编程报错 API流式传输失败解决方案

引言 如果大家在AI编程过程中遇到以下问题,可参考本文的解决方案。 大家好,我是逍遥小欢。昨天在我的老的win10电脑上,安装搭建AI编程vscode和roocode环境时,运行提示词遇到一个错误。 报错提示:API流式传输失败 Command failed…

龙虎榜——20250529

上证指数放量收阳线,个股涨多跌少,汽车主线方向凸显。 深证指数放量收阳线,可以围绕主线方向做。 2025年5月29日龙虎榜行业方向分析 1. 智能驾驶(政策落地场景延伸) 代表标的:云内动力、信邦智能。 …