Rust 配置解析`serde` + `toml`
🦀 Rust 配置解析:彻底搞懂 TOML、Option、Vec、derive 背后的原理
📌 目录
- 什么是 TOML 文件?
- 为什么要用
serde
+toml
crate? - 结构体上
#[derive(...)]
是什么? - 配置中数组
[]
和表数组[[...]]
怎么用? - 什么是可选字段?
Option<T>
如何工作? - 实战演练:读取配置并映射为 Rust 数据结构
- 总结
1️⃣ 什么是 TOML 文件?
TOML 是一种类似 ini 的配置文件格式,语法简单,适合人类阅读,常见于 Rust 工程的 Cargo.toml
。
一个典型的 TOML 文件:
name = "MyApp"
version = "1.0.0"
tags = ["rust", "serde", "toml"][[servers]]
name = "server1"
ip = "192.168.1.1"
port = 8080[[servers]]
name = "server2"
ip = "192.168.1.2"
port = 8081
2️⃣ 为什么要用 serde
+ toml
crate?
Rust 不内置解析配置文件的功能,所以我们使用两个库:
库名 | 用途 |
---|---|
serde | 通用序列化框架,能把 TOML 转换为 Rust 结构体 |
toml | 专门解析 TOML 的 crate,和 serde 搭配使用 |
📦 在你的 Cargo.toml
中添加依赖:
[dependencies]
serde = { version = "1.0", features = ["derive"] }
toml = "0.8"
3️⃣ #[derive(...)]
是什么?
在 Rust 中,你必须显式声明哪些功能你要让结构体拥有,比如:
#[derive(Debug, Deserialize)]
Debug
:允许你打印结构体内容,调试用。Deserialize
:告诉serde
可以把 TOML 字符串自动转换为这个结构体。
📌 如果你不加 Deserialize
,你就不能用 toml::from_str()
来自动解析配置,会编译报错!
4️⃣ TOML 中的数组 []
和表数组 [[...]]
怎么用?
➤ 普通数组
tags = ["rust", "serde", "toml"]
对应 Rust:
tags: Vec<String>,
➤ 表数组(数组中的结构体)
[[servers]]
name = "server1"
ip = "192.168.1.1"
port = 8080[[servers]]
name = "server2"
ip = "192.168.1.2"
port = 8081
对应 Rust:
servers: Vec<Server>,
其中 Server
是一个结构体类型。
5️⃣ 什么是 Option?为什么它代表“可选字段”?
如果你有字段在某些配置文件中可能会省略,比如 version
:
# version = "1.0.0" // 这行没写
你就不能定义为 version: String
,否则会报错。
✅ 正确写法是:
version: Option<String>,
- 有值时解析为
Some("1.0.0")
- 没值时解析为
None
这样你的配置就可以“少写字段”而不影响程序运行。
6️⃣ 实战:用 Rust 加载 TOML 配置文件
配置文件 config.toml
name = "MyApp"
tags = ["rust", "serde", "toml"][[servers]]
name = "server1"
ip = "192.168.1.1"
port = 8080[[servers]]
name = "server2"
ip = "192.168.1.2"
port = 8081
Rust 代码
use serde::Deserialize;
use std::fs;#[derive(Debug, Deserialize)]
struct Config {name: String,version: Option<String>, // 可选字段tags: Vec<String>, // 数组servers: Vec<Server>, // 表数组
}#[derive(Debug, Deserialize)]
struct Server {name: String,ip: String,port: u16,
}fn main() {let content = fs::read_to_string("config.toml").expect("无法读取文件");let config: Config = toml::from_str(&content).expect("TOML 解析失败");println!("{:#?}", config);// 示例用法if let Some(version) = &config.version {println!("版本号: {}", version);} else {println!("未指定版本号");}for server in &config.servers {println!("服务器: {} -> {}:{}", server.name, server.ip, server.port);}
}
🧪 输出结果示例
Config {name: "MyApp",version: None,tags: ["rust","serde","toml",],servers: [Server {name: "server1",ip: "192.168.1.1",port: 8080,},Server {name: "server2",ip: "192.168.1.2",port: 8081,},],
}
7️⃣ 总结一张图:结构体 vs TOML 映射关系
Rust 字段类型 | TOML 写法 | 是否可省略 | 说明 |
---|---|---|---|
String | name = "MyApp" | ❌ 否 | 不能省略,否则报错 |
Option<String> | version = "1.0.0" | ✅ 是 | 省略时为 None |
Vec<String> | tags = ["a", "b"] | ❌ 否 | 普通数组 |
Vec<Struct> | [[servers]] ... | ❌ 否 | 表数组(嵌套结构) |
📚 延伸阅读
- serde 官方文档
- toml crate 文档
- Rust 类型系统介绍(Option 和 Result)
相关文章:
Rust 配置解析`serde` + `toml`
🦀 Rust 配置解析:彻底搞懂 TOML、Option、Vec、derive 背后的原理 📌 目录 什么是 TOML 文件?为什么要用 serde toml crate?结构体上 #[derive(...)] 是什么?配置中数组 [] 和表数组 [[...]] 怎么用&…...
linux进程用户态内存泄露问题从进程角度跟踪举例
我们习惯性的会看下那个进程在泄漏内存,我这里使用一个test_malloc的测试进程,该进程每2秒钟会分配一个10000字节的空间,并作简单赋值(注意:如果仅malloc而不使用,编译器会优化,实际测试时将看不…...

数据结构-图的应用,实现环形校验和拓扑排序
文章目录 一、如何理解“图”?1.什么是图?2.无向图和有向图3.无权图和有权图 二、JGraphT-图论数据结构和算法的 Java 库1.引入Maven依赖2.环形校验2.1 什么是循环依赖 ?2.2 单元测试代码2.3 情况1:自己依赖自己2.4 情况2…...
交换机 路由器
在计算机网络中,S 和 R 常常分别代表以下设备: S:Switch(交换机)R:Router(路由器) 简要说明: Switch(交换机,S) 交换机工作在数据链…...

某乎x-zse-96 破解(补环境版本)
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 一、总体概述二、请求分析分析请求流程三、逆向分析总结一、总体概述 本文主要实现某乎x-zse-96 破解(补环境版本),相关的链接: https://www.zhihu.com/search?type=content&q=%25E7%258…...

VSCode+Cline 安装配置及使用说明
安装配置 打开VSCode,点击左侧Extension图标,在弹出页面中,检索Cline,选择Cline进行安装。 安装完毕,在左侧会出现一个图标,点击图标 选择【Use your own API key】,在出来的界面中选择大模型&…...
Java中Redis面试题集锦(含过期策略详解)
🤟致敬读者 🟩感谢阅读🟦笑口常开🟪生日快乐⬛早点睡觉 📘博主相关 🟧博主信息🟨博客首页🟫专栏推荐🟥活动信息 文章目录 Java中Redis面试题集锦(含过期策…...

Maven 安装与配置指南(适用于 Windows、Linux 和 macOS)
Apache Maven 是一款广泛应用于 Java 项目的项目管理和构建工具。 本文提供在 Windows、Linux 和 macOS 系统上安装与配置 Maven 的详细步骤,旨在帮助开发者快速搭建高效的构建环境。 一、前置条件:安装 Java Development Kit (JDK) Maven 依赖于 Java …...

android 媒体框架之MediaCodec
一、MediaCodec 整体架构与设计思想 MediaCodec 是 Android 底层多媒体框架的核心组件,负责高效处理音视频编解码任务。其架构采用 生产者-消费者模型,通过双缓冲区队列(输入/输出)实现异步数据处理: 输入缓冲区队列…...

堆与堆排序及 Top-K 问题解析:从原理到实践
一、堆的本质与核心特性 堆是一种基于完全二叉树的数据结构,其核心特性为父节点与子节点的数值关系,分为大堆和小堆两类: 大堆:每个父节点的值均大于或等于其子节点的值,堆顶元素为最大值。如: 小堆:每个…...
Linux中检查当前用户是不是root
Linux中检查当前用户是不是root 检查当前用户是否为root用户。如果是root用户,输出“当前用户是root”;否则,输出“当前用户不是root”。 创建一个 aaa.sh脚本文件 写入如下内容 #!/bin/bash# 检查当前用户的UID是否为0(root用…...

软件锁:守护隐私,安心无忧
数字化时代,手机已成为我们生活中不可或缺的一部分,它不仅存储着我们的个人信息、照片、聊天记录等重要数据,还承载着我们的社交、娱乐和工作等多种功能。然而,这也意味着手机上的隐私信息面临着诸多泄露风险。无论是家人、朋友还…...

无人机桥梁3D建模、巡检、检测的航线规划
无人机桥梁3D建模、巡检、检测的航线规划 无人机在3D建模、巡检和检测任务中的航线规划存在显著差异,主要体现在飞行高度、航线模式、精度要求和传感器配置等方面。以下是三者的详细对比分析: 1. 核心目标差异 任务类型主要目标典型应用场景3D建模 生成…...
项目:贪吃蛇实现
头文件 snake.h #include<stdio.h> #include<stdlib.h> #include<windows.h> #include<locale.h> #include<stdbool.h> #include<time.h>#define POS_X 24#define POS_Y 5 #define BODY L● #define FOOD L★ #define KEY_PRESS(VK) ((…...

【Java基础05】面向对象01
文章目录 1. 设计对象并使用1.1 类与对象1.2 封装1.2.1 private关键字1.2.2 this关键字成员变量和局部变量的区别 1.2.3 构造方法1.2.4 标准JavaBean类 1.3 对象内存图 本文部分参考这篇博客 1. 设计对象并使用 1.1 类与对象 public class 类名{1、成员变量(代表属性,一般是名…...

设计模式:观察者模式 - 实战
一、观察者模式场景 1.1 什么是观察者模式? 观察者模式(Observer Pattern)观察者模式是一种行为型设计模式,用于定义一种一对多的依赖关系,当对象的状态发生变化时,所有依赖于它的对象都会自动收到通知并更…...
8.8 Primary ODSA service without ODSA Portal
主要ODSA服务(不使用ODSA门户) 以下场景描述如下情况: • 主ODSA客户端应用程序被允许用于该类型的主设备,且对终端用户启用(已授权)。 • 服务提供商(SP)能够在不涉及ODSA门户Web服…...

YOLOv8 移动端升级:借助 GhostNetv2 主干网络,实现高效特征提取
文章目录 引言GhostNetv2概述GhostNet回顾GhostNetv2创新 YOLOv8主干网络改进原YOLOv8主干分析GhostNetv2主干替换方案整体架构设计关键模块实现 完整主干网络实现YOLOv8集成与训练模型集成训练技巧 性能对比与分析计算复杂度对比优势分析 部署优化建议结论与展望 引言 目标检…...

国产化Word处理控件Spire.Doc教程:在 C# 中打印 Word 文档终极指南
在 C# 中以编程方式打印 Word 文档可以简化业务工作流程、自动化报告和增强文档管理系统。本指南全面探讨如何使用Spire.Doc for .NET打印 Word 文档,涵盖从基本打印到高级自定义技术的所有内容。我们将逐步介绍每种情况下的实际代码示例,确保您能够在实…...
java的vscode扩展插件
在 Visual Studio Code (VSCode) 中,Java 开发可以通过多种方式得到支持,包括安装专门的扩展插件。下面是一些流行的 VSCode 扩展插件,可以帮助你更好地进行 Java 开发: Language Support for Java(TM) by Red Hat 官方支持&…...

谷歌:贝叶斯框架优化LLM推理反思
📖标题:Beyond Markovian: Reflective Exploration via Bayes-Adaptive RL for LLM Reasoning 🌐来源:arXiv, 2505.20561 🌟摘要 通过强化学习 (RL) 训练的大型语言模型 (LLM) 表现出强大的推理能力和紧急反射行为&a…...

Qt SQL模块基础
Qt SQL模块基础 一、Qt SQL模块支持的数据库 官方帮助文档中的Qt支持的数据库驱动如下图: Qt SQL 模块中提供了一些常见的数据库驱动,包括网络型数据库,如Qracle、MS SQL Server、MySQL等,也包括简单的单机型数据库。 Qt SQL支…...

[9-3] 串口发送串口发送+接收 江协科技学习笔记(26个知识点)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26中断...
java 微服务中,微服务相互调用 feign 和flux 如何选择
在 Java 微服务中,Feign 和 Flux(通过 WebClient 实现)是两种不同的服务间调用方式,主要区别体现在编程模型、通信机制和适用场景上。 1. 编程模型 FeignFlux (WebClient)同步阻塞式:基于传统 Servlet 模型࿰…...

如何在Qt中绘制一个带有动画的弧形进度条?
如何在Qt中绘制一个弧形的进度条 在图形用户界面开发中,进度指示控件(Progress Widget)是非常常见且实用的组件。CCArcProgressWidget 是一个继承自 QWidget 的自定义控件,用于绘制圆弧形进度条。当然,笔者看了眼公开…...
参加技术会议,为程序人生的职业生涯成长添砖加瓦
参加技术会议,为程序人生的职业生涯成长添砖加瓦 关键词:技术会议、程序员职业生涯、职业成长、技术交流、人脉拓展、知识体系升级、职业竞争力 摘要:在快速迭代的IT技术领域,参加技术会议已成为程序员突破职业瓶颈、构建核心竞争力的重要途径。本文从技术会议的核心价值出…...

国产三维CAD皇冠CAD(CrownCAD)建模教程:汽车电池
在线解读『汽车电池』的三维建模流程,讲解3D草图、保存实体、拉伸凸台/基体、设置外观等操作技巧,一起和皇冠CAD(CrownCAD)学习制作步骤吧! 汽车电池(通常指铅酸蓄电池或锂离子电池)是车辆电气系…...
记录算法笔记(2025.5.28)只出现一次的数字
给你一个 非空 整数数组 nums ,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。 你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。 示例 1 : 输入࿱…...

VMware-workstation安装教程--超详细(附带安装包)附带安装CentOS系统教程
VMware-workstation安装教程--超详细(附带安装包)附带安装CentOS系统教程 一、下载软件VMwware二、下载需要的镜像三、在VMware上安装系统 一、下载软件VMwware 二、下载需要的镜像 三、在VMware上安装系统 VMware 被 Broadcom(博通&#x…...

2025年- H63-Lc171--33.搜索旋转排序数组(2次二分查找,需二刷)--Java版
1.题目描述 2.思路 输入:旋转后的数组 nums,和一个整数 target 输出:target 在 nums 中的下标,如果不存在,返回 -1 限制:时间复杂度为 O(log n),所以不能用遍历,必须使用 二分查找…...