Rust use关键字妙用及模块内容拆分方法

 更新时间:2022年09月19日 11:40:20   作者:微凉秋意  
这篇文章主要介绍了Rust use关键字妙用|模块内容拆分,文中还给大家介绍use关键字的习惯用法,快速引用自定义模块内容或标准库,以此优化代码书写,需要的朋友可以参考下

前言

书接上文,本篇补充rust 组织管理中模块的细节知识,比如模块拆分。此外介绍use关键字的习惯用法,快速引用自定义模块内容或标准库,以此优化代码书写。

1、rust 中的use关键字

如果我说use与C/C++中的include或者是java、python中的import用法类似,想必此时的你定是头一歪,脑子里蹦出两个字——拿捏。没错,看完本篇文章心里会更加敞亮,变得自信满满。

1.1、将模块标识符引入当前作用域

  • use 关键字能够将模块标识符引入当前作用域
  • 但是谨记引入的时候也遵循私有权限的原则

例如:

mod front_of_house{
    pub mod hosting{
        pub fn add_to_waitlist(){}
        fn some_fun(){}
    }
}

use crate::front_of_house::hosting;

pub fn eat_at_restaurant(){
    hosting::add_to_waitlist();
    hosting::add_to_waitlist();
    hosting::some_fun();
}//这里并不能使用some_fun()函数,是报错内容

我们可以看到front_of_house模块中嵌套了一个公共模块hosting,但是我们知道公共模块里的内容也需要有pub修饰才能被调用。因此没有加pub关键字的第二个函数无法被调用,这就是遵循私有权限的体现。

1.2、use特点与习惯用法

我们习惯这样使用 use:

1.不直接引入具体的函数或者方法

  • 我们可以这样引入具体函数:use crate::front_of_house::hosting::add_to_waitlist;
  • 当代码比较多的时候,我们很难区分一个函数是本地自定义还是引用,因此不具体引用

2.引用函数或者方法最近的父模块

  • 不必引用最外层,以免代码冗余

3.对于struct、enum 等函数以外的内容需要指定到完整路径(本身)

  • 引入过后直接使用即可

例如:

use std::collections::HashMap;
fn main() {
    let mut map=HashMap::new();
    map.insert(1, 2);
    println!("{:?}",map);
}
//打印结果:{1,2}

如果一个类型在不同的模块中都有,那么就要引入到父模块(同名条目)

例如:

use std::fmt;
use std::io;

fn f1()->fmt::Result{}
fn f2()->io ::Result{}

5.针对同名条目可以使用as关键字来重命名类型

  • 指定到完整路径,给其中一个改名即可

例如:

use std::fmt::Result;
use std::io::Result as IOResult;

fn f1()-> Result<>{}
fn f2()-> IOResult<>{}

1.3、使用pub use 重新导出名称

  • 使用 use 将路径(名称)导入到作用域后,该名称在此作用域默认是私有的,外部无法访问
  • pub use:重导出
    • 将条目引入作用域
    • 该条目可以被外部代码引入到自己的作用域

1.4、使用外部包(package)以及标准库

  • Cargo.toml 添加依赖的包
  • 通过该网站自动下载资源:https://crates.io/
  • 但是默认网站是在国外,需要更换国内镜像
  • 这些内容在此专栏有文章讲的比较详细,不理解可以去翻阅一下

2.使用use将特定条目引入作用域

3.标准库(std)也被当作外部包

  • 无需修改Cargo.toml来包含std
  • 但是需要用 use 将 std 中的特定条目引入到当前作用域

1.5、使用嵌套路径清理大量 use 语句

当使用同一个包或模块下的多个条目时:

  • 使用嵌套路径在同一行内将多个条目引入
  • 路径相同的部分::{路径差异的部分}

例如:

use std::io;
use std::cmp::Ordering;

use std::{io,cmp::Ordering};
//前两行可用最后一行替代
  • 如果包含自身,需要使用self

例如:

use std::io;
use std::io::Write;

use std::io::{self,Write};
//依然是最后一行可替换前两行

1.6、通配符 *

  • 使用*可以把路径中所有的公共条目都引入到作用域
  • 需要谨慎使用,作用场景:
  • 测试:将所有被测试代码引入到 tests 模块(后续文章会有)
  • 有时被用于预导入(prelude)模块

2、模块内容拆分

将模块拆分为不同文件:

  • 模块定义时,如果模块名后面是;而不是代码块:
  • Rust 会从与模块同名的文件中加载内容,例如:

在这里插入图片描述

在这里插入图片描述

此时的lib.rs里不会报错,编译器看到mod front_of_house; 会在根目录src处找到front_of_house文件夹里的hosting.rs文件,使用pub use将函数引入到当前作用域(必须严格按照图示建立文件夹和文件)

  • 模块树的结构不会发生变化

随着模块逐渐变大,该技术让你可以把模块的内容移动到其他文件中

到这里 rust 的组织管理算是彻底告一段落了,这块内容不多,但是理解起来还是要下点功夫的

到此这篇关于Rustuse关键字妙用|模块内容拆分的文章就介绍到这了,更多相关Rustuse关键字内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Rust之Substrate框架中Core详解

    Rust之Substrate框架中Core详解

    Substrate是一个用于构建区块链的开发框架,它由Parity团队基于Rust语言开发而成,是一个开箱即用的区块链构造器,本文详细介绍了Substrate框架中的Core,需要的朋友可以参考下
    2023-05-05
  • 利用rust编一个静态博客工具

    利用rust编一个静态博客工具

    这篇文章主要为大家详细介绍了如何利用rust编一个静态博客工具,这个静态博客的工具主要是把md文档转为html静态网站/博客,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-12-12
  • Rust中的panic定义及触发条件详解

    Rust中的panic定义及触发条件详解

    这篇文章主要为大家介绍了Rust中的panic定义及触发条件详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • 在win10上使用mingw64编译器配置Rust开发环境和idea 配置Rust 插件

    在win10上使用mingw64编译器配置Rust开发环境和idea 配置Rust 插件

    在win10上配置 Rust 开发环境(使用 mingw64编译器)和 idea 配置 Rust 插件的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-03-03
  • Rust版本号的使用方法详解

    Rust版本号的使用方法详解

    在 Rust 项目中,版本号的使用遵循语义版本控制(Semantic Versioning)原则,确保版本号的变化能准确反映代码的变更情况,本文给大家详细解释了Rust版本号用法,需要的朋友可以参考下
    2024-01-01
  • Rust错误处理之`foo(...)?`的用法与错误类型转换小结

    Rust错误处理之`foo(...)?`的用法与错误类型转换小结

    foo(...)?语法糖为Rust的错误处理提供了极大的便利,通过结合map_err方法和From trait的实现,你可以轻松地处理不同类型的错误,并保持代码的简洁性和可读性,这篇文章主要介绍了Rust错误处理:`foo(...)?`的用法与错误类型转换,需要的朋友可以参考下
    2024-05-05
  • Rust 能够取代 C 语言吗

    Rust 能够取代 C 语言吗

    Rust 是 Mozilla 基金会的一个雄心勃勃的项目,号称是 C 语言和 C++ 的继任者,这篇文章主要介绍了Rust 能够取代 C 语言吗的相关知识,需要的朋友可以参考下
    2020-06-06
  • 深入理解Rust中Cargo的使用

    深入理解Rust中Cargo的使用

    本文主要介绍了深入理解Rust中Cargo的使用,Cargo简化了项目的构建过程,提供了依赖项管理,以及一系列方便的工作流程工具,下面就来具体的介绍一下如何使用,感兴趣的可以了解一下
    2024-04-04
  • Rust 文档注释功能示例代码

    Rust 文档注释功能示例代码

    Rust的文档注释使用特定的格式,以便通过 rustdoc工具生成 API 文档,本文给大家介绍Rust 文档注释功能,感兴趣的朋友跟随小编一起看看吧
    2024-04-04
  • 详解在Rust语言中如何声明可变的static类型变量

    详解在Rust语言中如何声明可变的static类型变量

    在Rust中,可以使用lazy_static宏来声明可变的静态变量,lazy_static是一个用于声明延迟求值静态变量的宏,本文将通过一个简单的例子,演示如何使用 lazy_static 宏来声明一个可变的静态变量,需要的朋友可以参考下
    2023-08-08

最新评论