Rust 工程配置

Rust 第22节 工程配置

release profile

发布配置

可自定义,对代码编译拥有更多的控制

cargo 主要有两个 profile

dev profile, 开发阶段,cargo build

relese profile 发布阶段 cargo build --release

在Cargo.toml中对相关属性进行修改

例如编译优化等级

rust 复制代码
[profile.dev]
opt-level 0

[profile.release]
opt-level 3

opt-level 是编译优化等级,等级越高,代码优化越多,编译时间越长

文档注释

文档注释

用于生成文档

生产HTML文档

使用 /// 进行标识

支持markdown 格式

使用命令 cargo doc

他会运行 rustdoc 工具

使用命令cargo doc --open 生产完直接打开

常用章节

///# Examples 示例区域

///```

///let a

///`` `

其他常用章节

Panics 可能发生panic的场景

Errors 可能发生的错误

在运行cargo test 时,会运行文档中的示例代码

///可以理解为函数的注释

整个lib文档,或者整个crate进行注释 //!

pub use 重新导出

回顾一些关键字

mod 创建一个mode模块

pub 声明某一数据为公共的

use 将一些数据进行导入

当开发者编写crate时,建立的一些目录层级是规范的标准的,方便的

但是当使用者使用这些库时,可能就不会很方便

例如:

有一个类型,路径为:

my_crate::some_module::another_mode::my_types;

而使用者使用时,路径太深了,他想使用的是这样

my_crate::my_types;

这个时候我们可以使用 pub use 进行重新导出

正常导入

rust 复制代码
use release_project::one::s1;
use release_project::one::shello;
use release_project::two::s2;

重新导入后

rust 复制代码
use release_project::s1;
use release_project::shello;
fn main() {
    println!("Hello, world!");

    let d1 = s1{
        name : "小红".to_string(),
        age : 12,
    };
    shello(d1);

}

lib.rs 文件代码

rust 复制代码
//! # Art
//! 两个结构体
 
//重新导出
pub use self::one::s1;
pub use self::one::shello;
pub use self::two::s2;

/// 模块1
pub mod one {

    ///结构体s1
    pub struct s1 {
        pub name : String,
        pub age : u32,
    }

    ///函数shello
    pub fn shello(data : s1) {
        println!("name :{},age:{}",data.name,data.age);
    }
}

///模块2
pub mod two {
    ///结构体s2
    pub struct s2 {
        pub name : String,
        pub age : u32,
    }
}
相关推荐
牧艺24 分钟前
从零到协同:构建类飞书在线文档系统的五个技术重难点
前端·人工智能
红尘散仙1 小时前
想写一个像样的终端 App?试试把 React 的开发体验搬进 Rust TUI
前端·rust
袋鼠云数栈UED团队2 小时前
一套 Spec-First 的 AI 编程工作流
前端·人工智能
袋鼠云数栈前端2 小时前
一套 Spec-First 的 AI 编程工作流
前端·ai+
angerdream2 小时前
Android手把手编写儿童手机远程监控App之vue3 路由守卫
前端
不服老的小黑哥2 小时前
AI规范驱动编程-harness工程项目实战
前端
vivo互联网技术2 小时前
从 Web 到桌面:基于 Tauri 2.0 + Vue 3 打造 vivo 线下门店「大头贴」拍照体验系统
前端·rust
光影少年2 小时前
React 合成事件机制、和原生事件区别、事件冒泡阻止
前端·react.js·掘金·金石计划
没有鸡汤吃不下饭2 小时前
告别手动对接口:我用 OpenAPI JSON 做了一个前端接口同步 Skill
前端·ai编程
空栈独白2 小时前
NestJS实战-前后端联调
前端