Rust项目结构Package和Crate-基础篇

1. Package和Crate

在 Rust 中,packagecrate 是两个重要的概念,用于组织和管理代码。它们分别表示不同层次的代码组织和封装。

1.1 Crate

  • 一个 crate 是一个 Rust 项目或库的编译单元,它可以包含多个模块和代码文件。一个 crate 可以是一个二进制可执行文件或一个库(例如,静态库或动态库)。
  • crate 是 Rust 的最小编译单元,每个 crate 都会生成一个独立的二进制文件或库文件。crate 中的模块和代码可以通过 use 关键字在其他 crate 中引用和重用。
  • crate 也可以被其他 crate 依赖,以在项目中使用外部库。这些外部库称为依赖库,可以在项目的 Cargo.toml 文件中指定。

1.2 Package

  • 一个 package 是一个包含一个或多个 crate 的更高级别的组织单元。通常,一个 package 包含一个主 crate,即二进制可执行文件或库,以及其他可能的辅助 crate
  • package 是由一个 Cargo.toml 文件定义的,它包含了项目的元数据(如名称、版本、作者等)以及项目的依赖配置。
  • package 可以包含多个 crate,这些 crate 可以是主 crate 的辅助模块或库,也可以是不同的二进制文件。

1.3 与Java对比

Java中的模块可以看做成Rust的Crate,而Java中的项目和Rust的Package可以看成是等价的。所以Rust的package和Java中的package不是一个概念。crate 是 Rust 中最小的编译单元,可以是项目的二进制文件或库。而 package 则是一个更高级别的组织单元,包含一个或多个相关的 crate,由一个 Cargo.toml 文件定义。crate 可以通过 use 关键字在其他代码中引用,而 package 可以被其他项目依赖和集成。

2. Package的格式

Package分为两种:

  • binary:应用模版
  • library: 库模版

Cargo使用文件放置的约定,以便轻松地深入了解新的Cargo包:

shell 复制代码
.
├── Cargo.lock
├── Cargo.toml
├── src/
│   ├── lib.rs
│   ├── main.rs
│   └── bin/
│       ├── named-executable.rs
│       ├── another-executable.rs
│       └── multi-file-executable/
│           ├── main.rs
│           └── some_module.rs
├── benches/
│   ├── large-input.rs
│   └── multi-file-bench/
│       ├── main.rs
│       └── bench_module.rs
├── examples/
│   ├── simple.rs
│   └── multi-file-example/
│       ├── main.rs
│       └── ex_module.rs
└── tests/
    ├── some-integration-tests.rs
    └── multi-file-test/
        ├── main.rs
        └── test_module.rs
  • Cargo.tomlCargo.lock 存储在你的包的根目录中(包根目录)。
  • 源代码放在 src 目录中。
  • 默认库文件是 src/lib.rs
  • 默认的可执行文件是 src/main.rs
    • 其他可执行文件可以放在 src/bin/ 目录中。
  • 基准测试放在 benches 目录中。
  • 示例放在 examples 目录中。
  • 集成测试放在 tests 目录中。

如果一个二进制、示例、基准测试或集成测试由多个源文件组成,在 src/binexamplesbenchestests 目录的子目录中放置一个 main.rs 文件以及额外的模块。可执行文件的名称将是目录名称。

通过命令:

shell 复制代码
cargo new --help

可以看出来创建有两种上面所述的:binarylibrary

2.1 创建binary

命令:

shell 复制代码
cargo new xxx --bin  

xxx: package名称

通过命令行创建可以看出来自包含了最简单的,而tests等其他的目录是需要自己手动建(可以看出来是非必须得)。

2.2 创建library

命令:

shell 复制代码
cargo new xxx --lib

xxx: package名称

从上图看出和binary的模版一样tests相关的目录没有创建需要手动创建非必须的。

3. 总结

  1. 通过工具cargo创建package有两类:binarylibrarybinary 是一个包含可执行文件的 Rust 项目,通常用于创建独立的可执行应用程序。,也就是Java中的带有main函数的Java类,library 一个库包中至少包含一个 Rust 代码文件(通常是 lib.rs),其中定义了模块、结构体、函数等等。
  2. benches模块,examples模块以及tests模块非必须。这个根据个人需要进行新建设置。

我是蚂蚁背大象,文章对你有帮助给项目点个❤关注我GitHub:mxsm,文章有不正确的地方请您斧正,创建ISSUE提交PR~谢谢! Emal:mxsm@apache.com

相关推荐
摇滚侠2 小时前
Spring Boot 3零基础教程,IOC容器中组件的注册,笔记08
spring boot·笔记·后端
程序员小凯4 小时前
Spring Boot测试框架详解
java·spring boot·后端
你的人类朋友5 小时前
什么是断言?
前端·后端·安全
程序员小凯6 小时前
Spring Boot缓存机制详解
spring boot·后端·缓存
i学长的猫6 小时前
Ruby on Rails 从0 开始入门到进阶到高级 - 10分钟速通版
后端·ruby on rails·ruby
用户21411832636027 小时前
别再为 Claude 付费!Codex + 免费模型 + cc-switch,多场景 AI 编程全搞定
后端
茯苓gao7 小时前
Django网站开发记录(一)配置Mniconda,Python虚拟环境,配置Django
后端·python·django
Cherry Zack7 小时前
Django视图进阶:快捷函数、装饰器与请求响应
后端·python·django
爱读源码的大都督8 小时前
为什么有了HTTP,还需要gPRC?
java·后端·架构
码事漫谈8 小时前
致软件新手的第一个项目指南:阶段、文档与破局之道
后端