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

rsut基础

这篇文章是实战性质的,也就是说原理部分较少,属于经验总结,rust对于模块的例子太少了。rust特性比较多(悲),本文的内容可能只是一部分,实现方式也不一定是这一种

关于 rust 模块的相关内容,准确来说:怎么在源码中引用其他模块的内容

  1. 关于 mod、 use 、as 这几个关键字(文件名)
  2. 关于 mod.rs 文件
  3. 关于 self、 super 、 crate 这几个路径关键字
  4. worksapce :本文不讨论,狭义上指的是cargo的 [workspace] 部分: 可参见 The [workspace] section
  5. package : 狭义上指的是cargo的 [package] 部分,参见 The [package] section
  6. crate :参见下文 关于 create 的定义和 cargo 管理下的 crate
  7. module :本文的重点, crate 里 会有多个 module,文本讨论重点就是 mod 之间相互引用的问题。

一、mod 关键字和 mod.rs 文件,其他普通文件 foo.rs 等

引用模块要搞清楚的:

  1. 是在哪里引用的,也就要引用的文件的位置
  2. 需要引用那个模块,跟这个文件的相对位置和绝对位置是什么

mod 关键字:

  1. 用来声明,表现方式是包裹一个代码块。也就是说这个代码块会成为一个单独的模块。
    • mod xxx { <rust语句块> } :内部写 rust 语句 。见 例一
    • #[path="...xxxx.rs"] mod xxx; :使用 path 属性 ,使用见例二
    • mod xxx { include!("...xxxx.rs") } :内部配合 include! 宏,使用见例二
  2. 用来声明(“引用”)其他“模块”。(一个文件隐含的表示为一个mod)
    假设使用 mod toy; 语句来引入一个模块,实际上这跟你在哪里写的这个语句有关系有关
    • 把当前的文件所在位置分为两类, 类型A:位置在 src/main.rs、 src/lib.rs 或者 xxx/.../mod.rs 位置上的文件; 类型B: 位置不在1中的文件。
    • 在位置类型 A 的文件使用代码 mod toy;,你实际上在告诉编译器,你需要的模块是与此文件同级的 toy.rs 或者 toy/mod.rs文件 。编译器会自己找下这两个被引用的位置,如果两个位置都有文件,则报错。见 例三
    • 在位置类型 B 的文件使用代码 mod toy;,你实际上在告诉编译器,你需要的模块是与此文件(假设文件名为 foo.rs)同级的 foo 文件夹下的 foo/toy.rs 或者 foo/toy/mod.rs 文件。编译器会自己找下这两个被引用的位置,如果两个位置都有文件,则报错。 见 例四

二、使用 use 和 as 关键字缩短导入语句,或者导出模块内容

use 关键字也有两个作用

  • 缩短语句,使用 use 为当前文件缩短长语句,减少重复性的代码,见 例子五
  • 配合 as 关键字一起使用,进一步减少重复代码,或者防止名字重复,或者取个顺眼的名字 例子六
  • 打包其他模块的内容,当做本模块的内容一起导出。见 例子七

三、使用 super 和 crate 进行相对路径和绝对路径(顶级路径)的访问

如果我们想要调用一个函数,我们需要知道它的路径。路径有两种形式:

  • 绝对路径(absolute path)从 crate 根部开始,以 crate 名或者字面量 crate 开头。 见例八
  • 相对路径(relative path)从当前模块开始,以 self、super 或当前模块的标识符开头。

见文档: 路径用于引用模块树中的项 - Rust 程序设计语言 中文版

四、关于 create 的定义和 cargo 管理下的 crate

我们都知道通过 cargo 创建出的工程中 src/main.rs 就是程序的入口,但是还有更多的使用方式。

  • rustc 命令 : rust编译器,就算没有cargo也可以生成程序,但是比较麻烦,这些都让cargo来处理就好
  • cargo 命令 : 项目管理工具

下面就是一些问题了

  1. 什么是 create ? rustc 的编译入口文件,这个文件就被当做 crate 文件。
  2. crate 类型: 有多种,最常见的是 bin 和 lib,其他类型参见 rust参考手册-链接
  3. cargo 怎么定义工程项目中哪些是需要编译的 crate 的? 参见: cargo手册-项目布局
▾ src/           # 包含源文件的目录lib.rs         # 库和包的主要入口点main.rs        # 包生成可执行文件的主要入口点▾ bin/         # (可选)包含其他可执行文件的目录*.rs▾ */           # (可选)包含多文件可执行文件的目录main.rs
▾ examples/      # (可选)示例*.rs▾ */           # (可选)包含多文件示例的目录main.rs
▾ tests/         # (可选)集成测试*.rs▾ */           # (可选)包含多文件测试的目录main.rs
▾ benches/       # (可选)基准*.rs▾ */           # (可选)包含多文件基准的目录main.rs

五、例子

例一:单文件,主函数和 toy 模块

  • 注意 run 函数需要加 pub 关键字,否则不会被导出

src/main.rs

mod toy {pub fn run() {println!("run toy");}
}fn main() {toy::run();
}

输出

run toy

例二:两个文件,主函数和另一个文件夹 toy 模块

src/toy_implements.rs

pub fn run() {println!("run toy_impl !");
}

src/main.rs

mod toy1 { // 方法1: 使用 include!include!("./toy_implements.rs");
}#[path ="./toy_implements.rs"] 
mod toy2; // 方法2: 使用 path 属性定位文件位置fn main() {toy1::run();toy2::run();
}

输出

run toy_impl !
run toy_impl !

例三:在 main.rs 中使用 mod toy;

src/toy.rs

pub fn run() {println!("run toy_impl !");
}

src/main.rs

mod toy;
fn main() {toy::run();
}

输出

run toy_impl !

例四:在 src/foo.rs 中使用 mod toy;

src/foo/toy.rs

pub fn run() {println!("run toy_impl !");
}

src/foo.rs

mod toy;
fn say_hi() {toy::run();
}

输出

run toy_impl !

例五:use 指令

之前,我们使用了 toy::run() 来调用 run 函数。现在,我们使用 use 关键字来导入 toy 模块里的内容,这样就能在 main 函数中直接使用

src/foo.rs

mod toy {pub fn run() {  // 注意使用 pub 关键字println!("run toy");}
}
fn main() {use toy::*; // 使用 use 导入 toy 模块里的内容run(); // 直接调用
}

例六: 在as配合use指令

src/foo.rs

mod toy {pub fn run() {  // 注意使用 pub 关键字println!("run toy");}
}
fn main() {use toy::run as toy_run; // 使用 use + as 导入 toy 模块里的内容toy_run();
}

例七: 使用pub use命令在mod.rs合并打包其他模块的东西

src/toy/runner.rs

pub fn dog_run() { println!("dog is run !"); }

src/toy/fly.rs

pub fn fly_bird() { println!("bird is fly !"); }

src/toy/bear.rs

pub fn bear_eat() { println!("bear is eat fish !"); }
pub fn bear_sleep() { println!("bear is go sleep !"); }

src/toy/mod.rs

mod runner; // 引入同级 runner.rs 文件
mod fly; // 引入同级 fly.rs 文件
mod bear; // 引入同级 bear.rs 文件
pub use runner::dog_run; // 声明(导出) dog_run 函数
pub use fly::fly_bird as now_fly_brid; // 声明(导出) fly_bird 函数,并重命名为 now_fly_brid
pub use bear::*; // 声明(导出) dog_run 函数

src/main.rs

mod toy;
fn main() {toy::dog_run();toy::now_fly_brid();toy::bear_eat();toy::bear_sleep();
}

输出

dog is run !
bird is fly !
bear is eat fish !
bear is go sleep !

例七: 使用pub mod导出内部包,使用 crate 引用顶部内容

src/toy/cube/mod.rs

pub fn get_size() {println!("size is in main");crate::top_size(); // 必不可少的 crate 关键字
}

src/toy/mod.rs

pub mod cube;

src/main.rs

mod toy;
fn top_size() {println!("top size one !")
}
fn main() {toy::cube::get_size();
}

输出

size is in main
top size one !

相关文章:

rsut基础

这篇文章是实战性质的&#xff0c;也就是说原理部分较少&#xff0c;属于经验总结&#xff0c;rust对于模块的例子太少了。rust特性比较多&#xff08;悲&#xff09;&#xff0c;本文的内容可能只是一部分&#xff0c;实现方式也不一定是这一种。 关于 rust 模块的相关内容&a…...

高压放大器和示波器的关系是什么

高压放大器和示波器是电子工程领域中常见的两种设备&#xff0c;它们在实际的电路设计、测试和分析中都扮演着重要的角色。下面安泰电子将从定义、功能、应用场景等方面为您介绍高压放大器和示波器的关系。 图&#xff1a;ATA-7000系列高压放大器 一、高压放大器的定义及功能 高…...

5个超实用视频素材网站,免费下载~

推荐几个高清无水印的视频素材网站&#xff0c;重点是可以免费下载使用&#xff0c;建议收藏&#xff01; 菜鸟图库 https://www.sucai999.com/video.html?vNTYxMjky 可以称之为最大素材库&#xff0c;在这里你可以找到设计、办公、图片、视频、音频等各种素材。视频素材就有…...

【NLP模型】文本建模(1)(BoW、N-gram、tf-idf)

目录 一、说明 二、BoW模型产生发展 2.1 产生和历史 2.2 原理介绍 三、具体实现...

Java——网络编程套接字

目录 一、网络编程基础 1.1 为什么需要网络编程&#xff1f;——丰富的网络资源 二、什么是网络编程? 三、网络编程中的基本概念 3.2 请求和响应 3.3 客户端和服务端 常见的客户端服务端模型 四、Socket套接字 五、通信模型 5.1 Java数据报套接字通信模型 5.2 Java流…...

160套小程序源码

源码列表如下&#xff1a; AppleMusic (知乎日报) 微信小程序 d artand 今日更新求职招聘类 医药网 口碑外卖点餐 城市天气 外卖小程序 定位天气 家居在线 微信小程序-大好商城&#xff0c;wechat-weapp 微信小程序的掘金信息流 微信跳一跳小游戏源码 微票源码-demo 急救应急处…...

有效项目进度管理的 10 条规则

项目进度管理是项目中比较关键的方面之一&#xff0c;因为它将决定事情的进展方式、进展速度以及是否会取得进展。换句话说&#xff0c;它可以让你较好地控制项目&#xff0c;帮助你预测不可预测的情况&#xff0c;并使所有相关团队能够高效地协同工作。 以下是有效项目进度管…...

javaWebssh服装租赁店信息管理系统台myeclipse开发mysql数据库MVC模式java编程计算机网页设计

一、源码特点 java ssh服装租赁店信息管理系统是一套完善的web设计系统&#xff08;系统采用ssh框架进行设计开发&#xff09;&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要 采用B/S模式开发。开发环境为TO…...

概率论:样本与总体分布,Z分数与概率

参考书目&#xff1a;《行为科学统计精要》&#xff08;第八版&#xff09;——弗雷德里克J格雷维特 数据及其样本的分布 描述一组数据分布 描述一组样本数据的分布 描述样本数据的均值和整体数据一样&#xff0c;但是样本标准差的公式除以了n-1&#xff0c;这里引入自由度的…...

【JavaSE】Java基础语法(十二):ArrayList

文章目录 1. ArrayList的构造方法和添加方法2. ArrayList类常用方法3. ArrayList存储学生对象并遍历 集合和数组的区别 : 共同点&#xff1a;都是存储数据的容器不同点&#xff1a;数组的容量是固定的&#xff0c;集合的容量是可变的 1. ArrayList的构造方法和添加方法 ArrayL…...

c++—封装:运算符重载、友元

1. 友元 &#xff08;1&#xff09;友元函数 ①是一种允许非类成员函数访问类的私有成员的一种机制&#xff1b;可以把一个函数指定为类的友元&#xff0c;也可以把整个类指定为另一个类的友元&#xff1b; ②友元函数在类作用域外定义&#xff0c;但需要在类体中进行声明&…...

【K8s】安全认证与DashBoard

文章目录 一、概述1、客户端2、认证、鉴权与准入控制 二、认证管理1、认证方式2、HTTPS证书认证 三、授权管理1、授权与RBAC2、Role 与 ClusterRole3、RoleBinding 与 ClusterRoleBinding4、案例&#xff1a;创建一个只能管理dev空间下Pods资源的账号 四、准入控制五、DashBoar…...

SpringMVC第七阶段:SpringMVC的增删改查(01)

SpringMVC的增删改查 1、准备单表的数据库 drop database if exists springmvc;create database springmvc;use springmvc; ##创建图书表 create table t_book(id int(11) primary key auto_increment, ## 主键name varchar(50) not null, ## 书名 author varchar(50) no…...

接口测试-Mock测试方法

一、关于Mock测试 1、什么是Mock测试&#xff1f; Mock 测试就是在测试过程中&#xff0c;对于某些不容易构造&#xff08;如 HttpServletRequest 必须在Servlet 容器中才能构造出来&#xff09;或者不容易获取的比较复杂的对象&#xff08;如 JDBC 中的ResultSet 对象&#…...

关于宝塔部署jar包和war包

文章目录 前言一、jar包部署二、war包部署1.maven如果打包不了使用命令打包2.安装Tomcat进行访问是否成功2.进入Tomcat目录进行配置war包 一、项目访问方法 前言 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、jar包部署 1.其实jar包没什么讲的&…...

SpringMVC框架面试专题(初级-中级)-第十节

欢迎大家一起探讨&#xff5e;如果可以帮到大家请为我点赞关注哦&#xff5e; 截止到本节关于SpringMVC的内容已经更新完毕&#xff0c;后续会更新SpringBoot框架的面试题&#xff1b;大家在背题的时候切记不要死记硬背&#xff0c;需要理解 这是什么&#xff1f;有什么操作&a…...

PCIe TLB事务层详解过程

目录 1.What is TLP 2.PCIe 4种不同的事务 2.1.Memory事务 ​​​​​​​2.2.IO事务 2.3.Configuration事务 2.4.Message...

RK3588平台开发系列讲解(项目篇)YOLOv5部署测试

平台内核版本安卓版本RK3588Linux 5.10Android 12文章目录 一、YOLOv5环境安装二、YOLOv5简单使用2.1、获取预训练权重文2.2、YOLOv5简单测试2.3、转换为rknn模型2.4、部署到 RK 板卡三、airockchip/yolov5简单测试3.1、转换成rknn模型并部署到板卡沉淀、分享、成长,让自己和他…...

基于变形模板的弱监督体图像分割

文章目录 Weakly Supervised Volumetric Image Segmentation with Deformed Templates摘要本文方法实验结果 Weakly Supervised Volumetric Image Segmentation with Deformed Templates 摘要 背景 有许多方法可以对网络进行弱监督训练来分割2D图像。依赖于对3D图像的2D切片的…...

python实现单例模式及其应用

单例模式是一种常见的设计模式&#xff0c;它保证一个类只能被实例化一次&#xff0c;并提供了一个全局访问点来获取这个唯一的实例。 在 Python 中&#xff0c;可以通过使用装饰器、元类或模块等方式实现单例模式。下面分别介绍这三种方法&#xff1a; 1.使用装饰器实现单例…...

PHP和Node.js哪个更爽?

先说结论&#xff0c;rust完胜。 php&#xff1a;laravel&#xff0c;swoole&#xff0c;webman&#xff0c;最开始在苏宁的时候写了几年php&#xff0c;当时觉得php真的是世界上最好的语言&#xff0c;因为当初活在舒适圈里&#xff0c;不愿意跳出来&#xff0c;就好比当初活在…...

测试markdown--肇兴

day1&#xff1a; 1、去程&#xff1a;7:04 --11:32高铁 高铁右转上售票大厅2楼&#xff0c;穿过候车厅下一楼&#xff0c;上大巴车 &#xffe5;10/人 **2、到达&#xff1a;**12点多到达寨子&#xff0c;买门票&#xff0c;美团/抖音&#xff1a;&#xffe5;78人 3、中饭&a…...

如何在看板中有效管理突发紧急任务

在看板中有效管理突发紧急任务需要&#xff1a;设立专门的紧急任务通道、重新调整任务优先级、保持适度的WIP&#xff08;Work-in-Progress&#xff09;弹性、优化任务处理流程、提高团队应对突发情况的敏捷性。其中&#xff0c;设立专门的紧急任务通道尤为重要&#xff0c;这能…...

拉力测试cuda pytorch 把 4070显卡拉满

import torch import timedef stress_test_gpu(matrix_size16384, duration300):"""对GPU进行压力测试&#xff0c;通过持续的矩阵乘法来最大化GPU利用率参数:matrix_size: 矩阵维度大小&#xff0c;增大可提高计算复杂度duration: 测试持续时间&#xff08;秒&…...

涂鸦T5AI手搓语音、emoji、otto机器人从入门到实战

“&#x1f916;手搓TuyaAI语音指令 &#x1f60d;秒变表情包大师&#xff0c;让萌系Otto机器人&#x1f525;玩出智能新花样&#xff01;开整&#xff01;” &#x1f916; Otto机器人 → 直接点明主体 手搓TuyaAI语音 → 强调 自主编程/自定义 语音控制&#xff08;TuyaAI…...

Swagger和OpenApi的前世今生

Swagger与OpenAPI的关系演进是API标准化进程中的重要篇章&#xff0c;二者共同塑造了现代RESTful API的开发范式。 本期就扒一扒其技术演进的关键节点与核心逻辑&#xff1a; &#x1f504; 一、起源与初创期&#xff1a;Swagger的诞生&#xff08;2010-2014&#xff09; 核心…...

【开发技术】.Net使用FFmpeg视频特定帧上绘制内容

目录 一、目的 二、解决方案 2.1 什么是FFmpeg 2.2 FFmpeg主要功能 2.3 使用Xabe.FFmpeg调用FFmpeg功能 2.4 使用 FFmpeg 的 drawbox 滤镜来绘制 ROI 三、总结 一、目的 当前市场上有很多目标检测智能识别的相关算法&#xff0c;当前调用一个医疗行业的AI识别算法后返回…...

大语言模型(LLM)中的KV缓存压缩与动态稀疏注意力机制设计

随着大语言模型&#xff08;LLM&#xff09;参数规模的增长&#xff0c;推理阶段的内存占用和计算复杂度成为核心挑战。传统注意力机制的计算复杂度随序列长度呈二次方增长&#xff0c;而KV缓存的内存消耗可能高达数十GB&#xff08;例如Llama2-7B处理100K token时需50GB内存&a…...

Webpack性能优化:构建速度与体积优化策略

一、构建速度优化 1、​​升级Webpack和Node.js​​ ​​优化效果​​&#xff1a;Webpack 4比Webpack 3构建时间降低60%-98%。​​原因​​&#xff1a; V8引擎优化&#xff08;for of替代forEach、Map/Set替代Object&#xff09;。默认使用更快的md4哈希算法。AST直接从Loa…...

【Android】Android 开发 ADB 常用指令

查看当前连接的设备 adb devices 连接设备 adb connect 设备IP 断开已连接的设备 adb disconnect 设备IP 安装应用 adb install 安装包的路径 卸载应用 adb uninstall 应用包名 查看已安装的应用包名 adb shell pm list packages 查看已安装的第三方应用包名 adb shell pm list…...