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

相关推荐
晨非辰20 小时前
Linux权限管理速成:umask掩码/file透视/粘滞位防护15分钟精通,掌握权限减法与安全协作模型
linux·运维·服务器·c++·人工智能·后端
毕设源码-钟学长1 天前
【开题答辩全过程】以 基于SpringBoot的智能书城推荐系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
青春男大1 天前
Redis和RedisTemplate快速上手
java·数据库·redis·后端·spring·缓存
张张努力变强1 天前
C++ 类和对象(四):const成员函数、取地址运算符重载全精讲
开发语言·数据结构·c++·后端
不吃香菜学java1 天前
springboot左脚踩右脚螺旋升天系列-整合开发
java·spring boot·后端·spring·ssm
奋进的芋圆1 天前
Java 锁事详解
java·spring boot·后端
郑州光合科技余经理1 天前
技术架构:海外版外卖平台搭建全攻略
java·大数据·人工智能·后端·小程序·架构·php
科威舟的代码笔记1 天前
SpringBoot配置文件加载顺序:一场配置界的权力游戏
java·spring boot·后端·spring
血小板要健康1 天前
Spring IoC & DI (下)
java·前端·spring boot·后端·spring·servlet·java-ee
PP东1 天前
Flowable学习(一)——spring boot 部署
后端·学习·flowable