01-开始Rust之旅

1. 下载Rust

        官方推荐使用 rustup 下载 Rust,这是一个管理 Rust 版本和相关工具的命令行工具。下载时需要连接互联网。

        这边提供了离线安装版本。本人学习的机器环境为: ubuntu x86_64,因此选用第②个工具链;

                1. rust-1.75.0-x86_64-pc-windows-gnu.msi

                2. rust-1.75.0-x86_64-unknown-linux-gnu.tar.gz

$ rustc --versionrustc 1.75.0 (82e1608df 2023-12-21)

2. 编写和运行 Rust 程序

    Rust 对编辑、工具或代码的存放位置没有特别的要求,因此如果你喜欢使用集成开发环境(IDE)而不是命令行,请随意使用你喜欢的集成开发环境。许多集成开发环境现在都在一定程度上支持 Rust;Rust 团队一直致力于通过 rust-analyzer 实现对集成开发环境的强大支持。

    vscode可直接安装rust-anslyzer插件;

        创建一个新的源文件,并将其命名为 main.rs。Rust 文件总是以 .rs 扩展名结尾如果你在文件名中使用了多个单词,惯例是使用下划线分隔它们。例如,使用 hello_world.rs 而不是 helloworld.rs。

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

        保存文件,在 Linux输入以下命令编译并运行文件:

$ rustc main.rs
$ ./main
Hello, Rust!

2.1 Rust 程序剖析

        这几行定义了一个名为 main 的函数。 main 函数很特别:它总是每个可执行 Rust 程序中运行的第一段代码。这里,第一行声明了一个名为 main 的函数,该函数没有参数,也不返回任何内容。如果有参数,则会放在括号 () 中。

        函数体用 {} 封装。Rust 要求在所有函数体周围使用大括号。好的做法是将开头的大括号与函数声明放在同一行,中间空一格

注意:如果你想在 Rust 项目中坚持使用一种标准样式,可以使用一个名为 rustfmt 的自动格式化工具,以特定样式格式化你的代码。Rust 团队已将该工具包含在标准 Rust 发行版中,就像 rustc 一样!

        main 函数的主体包含以下代码:

    println!("Hello, Rust!");

        这一行完成了这个小程序的所有工作:将文本打印到屏幕上。这里有四个重要细节需要注意:

        首先,Rust 风格是缩进四个空格,而不是制表符。

        其次, println! 调用的是 Rust 宏。如果它调用的是一个函数,就会以 println 的形式输入(去掉 ! )。使用 ! 意味着你调用的是宏而不是普通函数,而且宏并不总是遵循与函数相同的规则

        第三,您将看到 "Hello, world!" 字符串。我们将这个字符串作为参数传递给 println! ,然后字符串就会被打印到屏幕上。

        第四,我们用分号 ( ; ) 结束这一行,表示这个表达式结束,下一个表达式准备开始。Rust 代码的大多数行都以分号结束

2.2 编译和运行是不同的步骤

        在运行 Rust 程序之前,您必须使用 Rust 编译器对其进行编译,方法是输入 rustc 命令并将源文件的名称传给它,就像这样:

rustc main.rs

        如果你有 C 或 C++ 背景,就会发现这与 gcc 或 clang 类似。编译成功后,Rust 会输出一个二进制可执行文件。

g++ -o demo demo.cpp

        接着,运行main可执行程序,在终端即可输出"Hello, Rust"文本。

./main

        对于简单的程序来说,只用 rustc 进行编译就可以了,但随着项目的发展,你会希望管理所有选项,并方便共享代码。接下来,我们将向你介绍 Cargo 工具,它将帮助你编写真实世界的 Rust 程序。

3. Cargo

        Cargo 是 Rust 的构建系统和软件包管理器。大多数 Rustaceans 都使用这个工具来管理他们的 Rust 项目,因为 Cargo 可以为你处理很多任务,例如构建代码、下载代码所依赖的库,以及构建这些库。(我们把代码需要依赖的库称为依赖库)。

从这一点上看,和Android中的Gradle很像;

        最简单的 Rust 程序,比如我们目前编写的程序,不需要任何依赖库。如果我们用 Cargo 构建了 "Hello, Rust!"项目,它将只使用 Cargo 中负责构建代码的部分。当你编写更复杂的 Rust 程序时,你会添加依赖关系,如果你使用 Cargo 启动一个项目,添加依赖关系就会容易得多。

        请在终端输入以下命令检查 Cargo 是否已安装:

$ cargo --version
cargo 1.75.0 (1d8b05cdd 2023-11-20)

3.1 用Cargo创建项目

        让我们使用 Cargo 创建一个新项目,看看它与最初的 "Hello, Rust!"项目有何不同。回到你的项目目录(或你决定存储代码的地方)。然后,在任何操作系统上运行以下命令:

$ cargo new hello_cargo
$ cd hello_cargo

        第一条命令会创建一个名为 hello_cargo 的新目录和项目。我们将项目命名为 hello_cargo,Cargo 会在同名目录下创建文件。

        进入 hello_cargo 目录并列出文件。你会看到 Cargo 为我们生成了两个文件和一个目录:一个 Cargo.toml 文件和一个包含 main.rs 文件的 src 目录。

        它还初始化了一个新的 Git 仓库和一个 .gitignore 文件。如果在现有的 Git 仓库中运行 cargo new ,则不会生成 Git 文件;您可以使用 cargo new --vcs=git .

    注:Git 是一种常见的版本控制系统。您可以使用 --vcs 标志更改 cargo new 以使用其他版本控制系统或不使用版本控制系统。运行 cargo new --help 查看可用选项。

        在文本编辑器中打开 Cargo.toml。它应该与下面代码相似。

[package]
name = "hell_cargo"
version = "0.1.0"
edition = "2021"# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html[dependencies]

        该文件采用 TOML(Tom's Obvious, Minimal Language)格式,是 Cargo 的配置格式。

        第一行 [package] 是一个章节标题,表示下面的语句正在配置一个软件包。当我们向该文件添加更多信息时,我们将添加其他部分。

        接下来的三行设置了 Cargo 编译程序所需的配置信息:名称、版本和要使用的 Rust 版本。

        最后一行, [dependencies] ,是列出项目依赖关系的开头部分。在 Rust 中,代码包被称为 crates。在本项目中,我们不需要任何其他依赖部分。

        现在打开 src/main.rs,看一看:

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

        Cargo 已经为你生成了一个 "Hello, world!"程序,就像我们之前编写的程序一样!到目前为止,我们的项目与 Cargo 生成的项目之间的区别在于:Cargo 将代码放在了 src 目录中,在顶层目录中添加了一个 Cargo.toml 配置文件。

        Cargo 希望你的源文件位于 src 目录中。项目顶层目录只用于存放 README 文件、许可证信息、配置文件以及其他与代码无关的内容。使用 Cargo 可以帮助你组织项目。每样东西都有自己的位置,每样东西都有自己的位置。

        如果你启动了一个不使用 Cargo 的项目,就像我们的 "Hello, world!"项目一样,你可以将它转换成一个使用 Cargo 的项目。将项目代码移至 src 目录,并创建一个合适的 Cargo.toml 文件。

3.2 构建及运行Cargo项目

        现在,让我们看看使用 Cargo 构建并运行 "Hello, world!"程序时会有哪些不同!在 hello_cargo 目录下,输入 cargo build 命令构建项目:

$ cargo buildCompiling hell_cargo v0.1.0 (/home/username/rustProj/hell_cargo)Finished dev [unoptimized + debuginfo] target(s) in 0.14s

        该命令会在 target/debug/hello_cargo 中创建一个可执行文件,而不是在当前目录下。由于默认编译是调试编译,因此 Cargo 会将二进制文件放到名为 debug 的目录中。你可以用这条命令运行可执行文件:

$ ./target/debug/hell_cargo 
Hello, world!

        如果一切顺利, Hello, world! 将打印到终端。首次运行 cargo build 还会导致 Cargo 在顶层创建一个新文件:Cargo.lock。该文件记录了项目中依赖项的确切版本。本项目中没有依赖项,所以文件有点少。你不需要手动修改这个文件,Cargo 会帮你管理它的内容

# This file is automatically @generated by Cargo.
# It is not intended for manual editing.
version = 3

[[package]]
name = "hell_cargo"
version = "0.1.0"

        我们刚用 cargo build 构建了一个项目,然后用 ./target/debug/hello_cargo 运行了它,但我们也可以用 cargo run 编译代码,然后在一条命令中运行生成的可执行文件:

cargo runCompiling hell_cargo v0.1.0 (/home/username/rustProj/hell_cargo)Finished dev [unoptimized + debuginfo] target(s) in 0.14sRunning `target/debug/hell_cargo`
Hello, world!

        使用 cargo run 比记住运行 cargo build 然后使用二进制文件的整个路径更方便,因此大多数开发人员使用 cargo run 。

        请注意,当我们再次运行 cargo run 时,这次我们没有看到 Cargo 正在编译 hello_cargo 的输出。Cargo 发现文件没有变化,所以没有重建,只是运行了二进制文件

cargo runFinished dev [unoptimized + debuginfo] target(s) in 0.00sRunning `target/debug/hell_cargo`
Hello, world!

        如果你修改了源代码,Cargo 会在运行前重建项目。

和Makefile功能类似;

        Cargo 还提供了一个名为 cargo check 的命令。该命令可快速检查您的代码,确保其可编译但不会生成可执行文件:

cargo checkChecking hell_cargo v0.1.0 (/home/username/rustProj/hell_cargo)Finished dev [unoptimized + debuginfo] target(s) in 0.02s

        为什么不需要可执行文件?通常, cargo check 要比 cargo build 快得多,因为它跳过了生成可执行文件的步骤。如果你在编写代码的过程中不断检查你的工作,那么使用 cargo check 将加快让你知道你的项目是否仍在编译的过程!因此,许多 Rustaceans 在编写程序时都会定期运行 cargo check ,以确保程序编译成功。然后在准备使用可执行文件时运行 cargo build 。

3.3 发布release版本

        当项目最终准备发布时,可以使用 cargo build --release 对其进行优化编译。该命令将在 target/release 而不是 target/debug 下创建可执行文件。优化会让 Rust 代码运行得更快,但开启优化会延长程序的编译时间

        这就是为什么有两种不同的配置文件:一种用于开发,当你想快速、频繁地重建程序时;另一种用于编译最终的程序,你将把它交给用户,它不会被反复重建,而且会尽可能快地运行。

        如果要对代码运行时间进行基准测试,请确保运行 cargo build --release ,并使用 target/release 中的可执行文件进行基准测试

cargo build --releaseCompiling hell_cargo v0.1.0 (/home/username/rustProj/hell_cargo)Finished release [optimized] target(s) in 0.14s

4. 将Cargo统一作为项目的编译工具

        对于简单的项目,Cargo 并不能提供比使用 rustc 更多的价值,但当你的程序变得越来越复杂时,它将证明自己的价值。一旦程序增加到多个文件或需要依赖关系,让 Cargo 来协调构建就容易多了。

        尽管 hello_cargo 项目很简单,但它使用了你在 Rust 职业生涯中将会用到的许多真正的工具。事实上,要处理任何现有项目,你都可以使用以下命令使用 Git 查看代码,切换到项目目录并构建:

$ git clone example.org/someproject
$ cd someproject
$ cargo build

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/416353.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

INTEWORK—PET 汽车软件持续集成平台

产品概述 INTEWORK-PET-CI是经纬恒润自主研发的汽车软件持续集成&持续交付平台,在传统的持续集成基础上深化了研运一体化(DevOps)的概念,将嵌入式软件中的拉取代码、检查、构建、测试、版本管理以及发布交付等环节串联起来&am…

Red Hat Enterprise Linux 6.10 安装图解

引导和开始安装 选择倒计时结束前,通过键盘上下键选择下图框选项,启动图形化安装过程。需要注意的不同主板默认或者自行配置的固件类型不一致,引导界面有所不同。也就是说使用UEFI和BIOS的安装引导界面是不同的,如图所示。若手动调…

市场复盘总结 20240119

仅用于记录当天的市场情况,用于统计交易策略的适用情况,以便程序回测 短线核心:不参与任何级别的调整,采用龙空龙模式 昨日主题投资 连板进级率 11/39 28.2% 二进三: 进级率低 43% 最常用的二种方法: 方…

Tensorflow2.0笔记 - 不使用layer方式,简单的MNIST训练

本笔记不使用layer相关API,搭建一个三层的神经网络来训练MNIST数据集。 前向传播和梯度更新都使用最基础的tensorflow API来做。 import tensorflow as tf from tensorflow import keras from tensorflow.keras import datasets import numpy as npdef load_mnist(…

一个简单的Web程序(详解创建一个Flask项目后自带的一个简单的Web程序)

程序代码截图如下: 1.应用初始化 在创建 Flask 程序时,通常需要先创建一个应用实例进行应用初始化。 from flask import Flask # 应用的初始化 app Flask(__name__) 上述代码中,使用 Flask 类创建了一个应用实例 app。 __name__ 参数用…

Harbor离线安装

下载安装包 $ wget https://github.com/goharbor/harbor/releases/download/v2.7.4/harbor-offline-installer-v2.7.4.tgz解压 $ tar xvf harbor-offline-installer-v2.7.4.tgz -C /usr/local修改配置 $ cd /usr/local/harbor $ cp harbor.yml.tmpl harbor.yml $ vim harbo…

Web自动化测试中的接口测试

1、背景 1.1 Web程序中的接口 1.1.1 典型的Web设计架构 web是实现了基于网络通信的浏览器客户端与远程服务器进行交互的应用,通常包括两部分:web服务器和web客户端。web客户端的应用有html,JavaScript,ajax,flash等&am…

驾驭车联网的力量:深入车联网网络架构

车联网,作为移动互联网之后的新风口,以网联思想重新定义汽车,将其从简单的出行工具演化为个人的第二空间。车联网涵盖智能座舱和自动驾驶两大方向,构建在网联基础上,犀思云多年深度赋能汽车行业,本文将从车…

鸿蒙HarmonyOS实战-ArkTS语言(基本语法)

🚀一、ArkTS语言基本语法 🔎1.简介 HarmonyOS的ArkTS语言是一种基于TypeScript开发的语言,它专为HarmonyOS系统开发而设计。ArkTS语言结合了JavaScript的灵活性和TypeScript的严谨性,使得开发者能够快速、高效地开发出高质量的Har…

Kali在Vmware无法连接到网络,配置网络及解决办法

一.问题描述: 打开 Kali,无法连接到网络,虚拟机配置正常的。 尝试 ping 百度,出错: ping baidu.com 提示: ping: baidu.com: Temporary failure in name resolution二.解决办法: 1.首先在vmwa…

操作系统-操作系统的运行机制(内核程序 应用程序 特权指令 非特权指令 内核态 用户态 变态)

文章目录 总览预备知识:程序是如何运行的?内核程序vs应用程序特权指令vs非特权指令内核态vs用户态用户态,内核态的切换小结 总览 预备知识:程序是如何运行的? 转换为机器码放入内存,然后按顺序执行 内核…

三极管这个功能比“放大”还常用?

同学们大家好,今天我们继续学习杨欣的《电子设计从零开始》,这本书从基本原理出发,知识点遍及无线电通讯、仪器设计、三极管电路、集成电路、传感器、数字电路基础、单片机及应用实例,可以说是全面系统地介绍了电子设计所需的知识…