Rust 第三方库创建和导入(cargo --lib)

前言

日常开发过程中,难免会有一些工具方法,多个项目之间可能会重复使用。

所以将这些方法集成到一个第三方包中方便后期维护和管理,

比如工具函数如果需要修改,多个项目可能每个都需要改代码,

抽离到单独的包中只需要修改包里面的代码和版本即可,其他项目更新一下版本无需多次修改。

对【RUST实际开发过程中模块之间的互相调用】不清楚的,可以点此进行查看

步骤

说明

这里业务代码项目名称为test_code,包名称rust_math(一些简单的计算方法)

开始

  • 执行以下命令
sh 复制代码
  cargo new test_code
  • 使用编辑器打开此目录,在此目录下新建一个包,执行以下命令
sh 复制代码
  cargo new rust_math --lib

目录结构

在业务项目的Cargo.toml中添加以下代码,引入本地包

toml 复制代码
[dependencies]
rust_math = { path = "./rust_math" }

包代码编写

在rust_math/src/lib.rs中编写以下代码

rust 复制代码
pub fn add(left: usize, right: usize) -> usize {
    left + right
}

#[cfg(test)]
mod tests {
    use super::*;
    #[test]
    fn it_works() {
        let result = add(2, 2);
        assert_eq!(result, 4);
    }
}

其中主要方法为add用于返回两数之和,下面的代码为单元测试

业务代码编写

在src/main.rs中编写以下代码

rust 复制代码
use rust_math;

fn main() {
    let sum: usize = rust_math::add(1, 1);
    println!("{}", sum);
}

运行

sh 复制代码
cargo run

运行结果

sh 复制代码
2
相关推荐
2013编程爱好者9 小时前
Vue工程结构分析
前端·javascript·vue.js·typescript·前端框架
是小胡嘛10 小时前
C++之Any类的模拟实现
linux·开发语言·c++
小满zs10 小时前
Next.js第十一章(渲染基础概念)
前端
csbysj202011 小时前
Vue.js 混入:深入理解与最佳实践
开发语言
不羁的fang少年11 小时前
前端常见问题(vue,css,html,js等)
前端·javascript·css
change_fate11 小时前
el-menu折叠后文字下移
前端·javascript·vue.js
yivifu11 小时前
CSS Grid 布局详解(2025最新标准)
前端·css
uzong12 小时前
Mermaid: AI 时代画图的魔法工具
后端·架构
Gerardisite12 小时前
如何在微信个人号开发中有效管理API接口?
java·开发语言·python·微信·php
Want59512 小时前
C/C++跳动的爱心①
c语言·开发语言·c++