0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何安装和使用cargo

科技绿洲 来源:TinyZ 作者:TinyZ 2023-09-20 11:28 次阅读

Cargo是Rust语言的包管理器和构建工具。它能够帮助我们管理依赖、构建项目、运行测试和发布程序等。在Rust社区中,Cargo已经成为了标准的构建工具,它为Rust的开发者提供了极大的便利。

安装和使用 cargo

在安装Rust时,Cargo也已经随之安装。 如果你还没有安装Rust,可以参考系列教程的第一篇 Rust语言从入门到精通系列 - Hello World!, 也可以前往官网 下载安装包进行安装。 安装完成后,可以通过以下命令来检查Cargo是否安装成功:

cargo --version
# cargo 1.68.0 (115f34552 2023-02-26)

输出了Cargo的版本号,说明安装成功。环境检查完成,下面开始Cargo的学习。

我们先回顾一下上一篇文章中使用过的Cargo命令。 第一个使用Cargo命令是"cargo new", 创建了我们的第一个Rust项目。没看过第一篇的同学可以尝试如下命令创建:

cargo new hello_world

这条命令会在当前目录下创建一个名为hello_world的新项目。其中,hello_world是项目的名称,可以根据自己的需要进行修改。 创建完成后,打开项目的目录hello_world。

目录结构如下图所示:

/
├── Cargo.lock
├── Cargo.toml
├── crate-information.json
├── src/
│   ├── main.rs
└── target/
└── tools/

Cargo生成的最基本的项目结构,包括src目录(用于存放开发的源代码)和Cargo.toml文件(管理项目元数据、编译构建、第三方库依赖等等)。

在src目录下,我们看到一个名为main.rs的文件,它是Rust程序的入口文件,内部实现一个默认的main()方法:

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

在main()方法体中输入 println!("Hello, world!"); 这就是一个非常简单的程序,它的功能是再命令提示符窗口打印输出一句话“Hello, world!”。在VS Code中按 F5 运行你的第一个程序吧。

假如你没有配置VS Code启动配置,那么再运行程序之前,Cargo会先使用build命令来构建项目,生成可执行文件。 至此,我们又新接触了一个cargo命令 build:

cargo build

cargo build 命令会在项目的根目录下生成一个target目录,其中包含了构建后的二进制文件。在默认情况下,Cargo会生成一个名为hello_world的二进制文件。

如果只想编译项目而不生成二进制文件,可以使用以下命令:

cargo check

这条命令会检查代码是否可以编译通过,但不会生成二进制文件。

在构建完成后,我们可以使用以下命令来运行程序:

cargo run

这条命令会自动编译并运行项目。如果一切正常,你应该能够看到和Vs Code按F5启动一样的“Hello, world!”的输出。

常用指令

上一小节,我们使用了Cargo的new,build, run, check四个指令,除了这几个指令外,Cargo 还提供了更多的指令,下面列举并注释其中最常用的一些指令:

  • • new: 指令可以创建一个新的 Rust 项目。它有两个参数,第一个参数是项目名称,第二个参数是项目类型,可以是 bin 或 lib。默认情况下,new 会创建一个二进制bin项目。
  • • init: 指令可以将当前目录初始化为一个 Rust 项目。它会创建一个默认的 src 目录和 Cargo.toml 文件。
  • • check: 指令可以检查代码是否可以编译通过,但 不会生成二进制文件
  • • build: 指令可以编译 Rust 项目,并生成二进制文件。如果项目已经编译过,build 指令会跳过编译过程。
  • • run: 指令可以编译并运行 Rust 项目。如果项目已经编译过,run 指令会跳过编译过程。
  • • test: 指令可以运行项目中的测试。测试代码通常放在 src/test.rs 或 src/lib.rs 中。
  • • bench: 指令可以运行项目中的基准测试。基准测试用来测试代码的性能。
  • • doc: 指令可以生成项目的文档。文档通常使用 Rust 内置的文档工具 rustdoc 来生成。
  • • clean: 指令可以清除项目的构建文件和生成的二进制文件。
  • • update: 指令可以更新项目中的依赖。
  • • publish: 指令可以将项目发布到 crates.io 上,供其他人使用。

更多指令可以通过 cargo --help 或 cargo --help 查看。

自定义扩展指令

依赖管理

在Rust项目中,我们可以使用Cargo来管理依赖。可以通过编辑Cargo.toml文件来添加依赖。 例如,我们想要使用rand库来生成随机数,可以在Cargo.toml文件中添加以下内容:

[dependencies]
rand = "0.8.4"

这条语句告诉Cargo,我们需要使用rand库,并且希望使用版本号为0.8.4的版本。在保存文件后,可以使用以下命令来安装依赖:

cargo build

这条命令会自动下载并安装依赖。 在代码中使用依赖时,我们需要在main.rs文件中添加以下语句:

use rand::Rng;

fn main() {
    let mut rng = rand::thread_rng();
    let n: u8 = rng.gen();
    println!("Random number: {}", n);
}

这里,我们使用了rand库中的Rng trait和thread_rng函数来生成随机数。

版本号控制

上面的示例我们引入了指定0.8.4版本的rand库依赖,并在命令提示符中打印了随机数。这里我们进一步对依赖管理进行学习。

除了指定依赖的特定版本外,我们还可以使用逻辑运算符控制版本范围, 具体如下:

  • • =: 等于某个版本。等同于直接填写版本号
  • • >: 大于某个版本。
  • • <=: 小于等于某个版本。
  • • : 大约等于某个版本,例如1.2.3表示大约等于1.2.3,但是允许最后一位数字不同,例如1.2.4。
  • • ^: 兼容某个版本,例如^1.2.3表示兼容1.2.x系列的所有版本,但是不兼容2.0.0及以上版本。

假如我们想指定依赖库的版本号大于等于0.7.3版本 且 小于0.8.4,示例:

[dependencies]
rand = " >=0.7.3, < 0.8.4"

指定依赖项的特性

有些库提供了多个特性,可以用来启用或禁用某些功能。例如,serde库提供了一个名为derive的特性,用于启用派生宏。为了指定依赖项的特性,可以使用如下语法:

[dependencies]
库名称 = { version = "版本号", features = ["特性名称"] }

log是一个用于日志记录的库。它提供了多个特性,可以用来启用或禁用某些功能。下面是一些常见的特性及其用途:

  • • std: 用于启用log的标准库支持,可以在标准库环境中使用log。
  • • env_logger: 用于启用log的环境变量支持,可以使用环境变量来控制日志输出。
  • • log4rs: 用于启用log的log4rs支持,可以使用log4rs库来配置日志输出。
  • simplelog: 用于启用log的simplelog支持,可以使用simplelog库来配置日志输出。

下面是一个示例:

[dependencies]
log = { version = "0.4", features = ["std"] }

除了启用特性之外,还可以禁用特性,例如:

[dependencies]
log = { version = "0.4", default-features = false }

指定依赖项的路径

在某些情况下,我们可能需要使用本地文件系统中的库。为了指定依赖项的路径,可以使用如下语法:

[dependencies]
rand = { path = "../rand" }

在这个例子中,我们指定了一个名为rand的库,路径为../rand。这告诉Cargo编译器,我们的项目需要使用本地文件系统中的rand库。当我们运行cargo build命令时,Cargo会自动编译指定路径下的rand库,并将它添加到我们的项目中。

除了使用本地文件系统中的库之外,我们还可以使用git仓库中的库。为了指定依赖项的git仓库,可以使用如下语法:

[dependencies]
rand = { git = "https://github.com/rust-lang-nursery/rand.git" }

项目元数据

本文的前面章节介绍了Cargo的常用质量,依赖管理特性。本小节主要讲解Cargo.toml文件中定义的程序元数据,例如:程序的名称、版本号、作者和描述等信息

[package]
##    项目名(程序名称)
name = "hello_world"
##    版本号
version = "0.1.0"
##    作者, 多个按逗号分隔
authors = ["Your Name < your_email@example.com >"]
##    项目描述
description = "A hello world program in Rust."
##    Rust语言的版本,目前支持2015、2018和2021 三个版本。
edition = "2021"

除了基础的元数据外,我们还可以在[package.metadata]下自定义专属的元数据:

[package.metadata]
url = "https://github.com/username/hello-world"
doc = "https://docs.rs/hello-world"
repository = "https://github.com/username/hello-world.git"

总结

通过本文的介绍,我们了解了Rust语言的包管理器和构建工具Cargo。学习了如何创建一个新的Rust项目、编写Rust程序、构建和运行程序、添加依赖等操作。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 安装
    +关注

    关注

    2

    文章

    98

    浏览量

    22265
  • 程序
    +关注

    关注

    117

    文章

    3785

    浏览量

    80999
  • 管理器
    +关注

    关注

    0

    文章

    246

    浏览量

    18502
  • rust语言
    +关注

    关注

    0

    文章

    57

    浏览量

    3009
收藏 人收藏

    评论

    相关推荐

    如何在Rust中连接和使用MySQL数据库

    如何在Rust中连接和使用MySQL数据库。 安装 mysql 模块 这里我们假设你已经安装了Rust编程语言工具链,在本教程中,我们将使用 mysql crate来连接和使用MySQL数据库。要安装
    的头像 发表于 09-30 17:05 1666次阅读

    【MYD-Y6ULX试用体验】建立开发环境

    ,2018年,RUST官方已正式把嵌入式系统列为主要工作目标,期待RUST的嵌入式开发体验会有显著提升。安装在终端运行$ curl https:// sh.rustup.rs -sSf | sh这将
    发表于 03-27 16:46

    只会用Python?教你在树莓派上开始使用Rust

    。出现提示时,选择默认安装安装程序将在完成时通知您,尽管安装可能会花费一些时间,具体取决于您的连接。/p》 安装安装成功,但是您还不能开
    发表于 05-20 08:00

    基于matlab约束优化惩罚函数法

    一、简介clcclear allglobal box; global cargo; global lambda; global num_cargo;global num_box;global
    发表于 08-17 06:01

    如何在STM32 (Cortex M3)和GD32(RISC-V)上用Rust开发

    已经集成了 LLVM,所以本身就可以直接编译,不需要而外的编译器。当然,有些 rust 组件安装还是需要自己电脑上有编译器的,比如后面会提到的 cargo-binutils。不过在 Windows
    发表于 06-21 10:38

    【沁恒微CH32V307评估板试用体验】探索Rust编程语言的嵌入式开发——基于CH32V307【1】

    安装Rustup和Cargo在windows系统中,从官网下载rustup-init.exe,由于默认的msvc需要Visual Studio,所以本机采用mingw的版本,只需要安装MinGW的gcc
    发表于 07-18 00:37

    如何在构建yocto时将rust和cargo安装为图像?

    我正在使用 5.15.72。 当我制作 imx 完整图像时,我尝试包括 rust 和 cargo。 你知不知道怎么?
    发表于 05-09 07:10

    pads2007的安装方法 怎么安装 无法安装

    pads2007的安装方法 怎么安装  无法安装:图解说明,非常详细
    发表于 12-03 13:01 0次下载
    pads2007的<b class='flag-5'>安装</b>方法 怎么<b class='flag-5'>安装</b> 无法<b class='flag-5'>安装</b>

    基于E-CARGO的多任务分配管理

    多任务分配是管理和协同工作中的重要问题。采用E-CARGO建模来解决常规多任务分配问题( GMTAP)与组角色多任务分配问题(GRMTAP)。提出了两种算法:(l)通过把GMTAP质量评估矩阵转置
    发表于 11-23 14:58 11次下载
    基于E-<b class='flag-5'>CARGO</b>的多任务分配管理

    坐出租车也可购买商品?优步与Cargo正式合作后的计划

    据VentureBeat北京时间7月20日报道,Uber公布了允许司机在服务期间向乘客销售商品、赚外快的计划。这一计划的公布正值Uber与车内商务创业公司Cargo达成正式合作之际。
    的头像 发表于 08-05 09:25 2282次阅读

    cargo careful:为你的代码提供更多安全保证

    cargo careful 就是为了弥补这个差距,它在第一次调用时,会从源代码构建一个带有调试断言的标准库,然后使用该标准库运行您的程序或测试套件。
    的头像 发表于 10-27 09:52 456次阅读
    <b class='flag-5'>cargo</b> careful:为你的代码提供更多安全保证

    cargo-offline命令解读

    cargo-offline 命令 cargo-offline 是标准 cargo 命令的包装器。其被用来,根据·距离 cargo-offline 命令执行目录最近的
    的头像 发表于 12-01 15:41 1129次阅读

    基于Rust 编程语言的小游戏程序实例

    在编写程序之前你的电脑必须先安装好 Rust 的基础开发环境,并且有 Cargo 支持,如果你是其他编程语言转过来的例如 C、 Java 、Python 、JavaScript 、Swift 等
    发表于 12-15 10:53 1835次阅读

    Cargo如何访问世界上最强大的3D库

    Cargo简介 用于电影和视频游戏的高级3D资产在我们的新资产浏览器— Cargo中访问世界上最强大的3D库 每个套件。每个模型。每种材料。 一个全新的资产浏览器加载了你所有的工具包。   完整
    的头像 发表于 06-19 10:09 760次阅读

    CARGO:改变您使用3D资产的方式

    今天我们发布了Cargo,这款软件将彻底改变您使用3D资产的方式。Cargo适用于Windows,开箱即用,可与Blender、Unreal、3dsMax 和Maya等3D软件一起使用。让我们解开
    的头像 发表于 06-26 10:08 1003次阅读