什么是 TOML?

🛠 Rust 配置文件实战:TOML 语法详解与结构体映射(

在 Rust 中,Cargo.toml 是每个项目的心脏。它不仅定义了项目的名称、版本和依赖项,还使用了一种轻巧易读的配置语言:TOML

本文将深入解析 TOML 的语法,并带你一步步学会如何用 Rust 来读取并解析 TOML 文件,并最终将其映射为你可以直接使用的结构体对象。文章包括:

  • TOML 基本与复杂语法详解
  • Rust 中对应的数据结构表示

📘 什么是 TOML?

TOML,全称 Tom’s Obvious, Minimal Language,是一个专门为配置文件设计的语言,追求的是:

“人类易读 + 机器易解析”。

TOML 的语法非常接近 INI,但更加强大和一致性,是 Rust 官方默认的配置文件格式。


🔧 TOML 基本语法

1. 键值对(Key = Value)

name = "MyApp"
version = "1.0.0"
  • 键(key)和等号之间允许空格
  • 字符串必须用引号包裹

2. 注释

# 这是一个注释
name = "MyApp"  # 这也是注释

3. 支持的数据类型

数据类型示例
字符串"hello"'world'
整数42-1
浮点数3.14
布尔值truefalse
日期时间2023-01-01T12:00:00Z
数组[1, 2, 3]["a", "b"]

📦 表(Table)与嵌套结构

1. 表

[database]
host = "localhost"
port = 3306

相当于创建了一个 database 命名空间。

2. 嵌套表(Nested Table)

[owner]
name = "Tom"[owner.address]
street = "123 Elm"
city = "Springfield"

等价于:

{"owner": {"name": "Tom","address": {"street": "123 Elm","city": "Springfield"}}
}

📚 数组和数组表(Array of Tables)

1. 普通数组

fruits = ["apple", "banana", "pear"]

2. 数组中的表(Array of Tables)

[[servers]]
name = "Server1"
ip = "192.168.1.1"[[servers]]
name = "Server2"
ip = "192.168.1.2"

这表示 servers 是一个表数组,类似于:

{"servers": [{ "name": "Server1", "ip": "192.168.1.1" },{ "name": "Server2", "ip": "192.168.1.2" }]
}

🦀 在 Rust 中读取 TOML 配置

1. 添加依赖

Cargo.toml 中加入:

[dependencies]
serde = { version = "1.0", features = ["derive"] }
toml = "0.5"

2. 假设我们的配置如下(config.toml):

[app]
name = "MyApp"
version = "1.0.0"[[servers]]
name = "Server1"
ip = "192.168.1.1"
port = 8080[[servers]]
name = "Server2"
ip = "192.168.1.2"
port = 8081[database]
host = "localhost"
port = 3306
username = "root"
password = "secret"

3. Rust 中的结构体定义

use serde::Deserialize;#[derive(Debug, Deserialize)]
struct Config {app: App,servers: Vec<Server>,database: Database,
}#[derive(Debug, Deserialize)]
struct App {name: String,version: String,
}#[derive(Debug, Deserialize)]
struct Server {name: String,ip: String,port: u16,
}#[derive(Debug, Deserialize)]
struct Database {host: String,port: u16,username: String,password: String,
}

4. 加载并解析 TOML

fn main() {let config_str = std::fs::read_to_string("config.toml").expect("读取失败");let config: Config = toml::from_str(&config_str).expect("解析失败");println!("{:#?}", config);
}

🧾 解析后的数据长什么样?

运行 cargo run 后,你会看到打印出的结构体内容如下:

Config {app: App {name: "MyApp",version: "1.0.0",},servers: [Server {name: "Server1",ip: "192.168.1.1",port: 8080,},Server {name: "Server2",ip: "192.168.1.2",port: 8081,},],database: Database {host: "localhost",port: 3306,username: "root",password: "secret",},
}

你现在可以像正常使用结构体那样访问这些配置项:

println!("App Name: {}", config.app.name);
println!("DB Host: {}", config.database.host);
println!("First Server IP: {}", config.servers[0].ip);

✅ 总结

部分内容
配置文件格式TOML
Rust工具serde + toml crate
使用场景项目配置、插件配置、本地服务配置
优势层级清晰、易读、强类型映射支持

📌 附加:配置热更新方案(高级进阶)

  • 使用 notify crate 监听 TOML 文件变化
  • 使用 lazy_staticonce_cell 实现全局配置缓存
  • 定时 reload 或 on-change reload 配置

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/diannao/85739.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

react native webview加载本地HTML,解决iOS无法加载成功问题

在react native中使用 “react-native-webview”: “^13.13.5”,加载HTML文件 Android: 将HTML文件放置到android/src/main/assets目录&#xff0c;访问 {uri: file:///android_asset/markmap/index.html}ios: 在IOS中可以直接可以直接放在react native项目下&#xff0c;访问…

数据结构(JAVA版)练习题

&#xff08;题目难易程度与题号顺序无关哦&#xff09; 目录 1、多关键字排序 2、集合类的综合应用问题 3、数组排序 4、球的相关计算问题 5、利用类对象计算日期 6、日期计算问题 7、星期日期的计算 8、计算坐标平面上两点距离 9、异常处理设计问题 10、Java源文件…

04-redis-分布式锁-redisson

1 基本概念 百度百科&#xff1a;控制分布式系统之间同步访问共享资源方式。 在分布式系统中&#xff0c;常常需要协调他们的动作。如果不同的系统或是同一个系统的不同主机之间共享了一个或一组资源&#xff0c;那么访问这些资源的时候&#xff0c;往往需要互斥来防止…

性能优化 - 案例篇:缓存_Guava#LoadingCache设计

文章目录 Pre引言1. 缓存基本概念2. Guava 的 LoadingCache2.1 引入依赖与初始化2.2 手动 put 与自动加载&#xff08;CacheLoader&#xff09;2.2.1 示例代码 2.3 缓存移除与监听&#xff08;invalidate removalListener&#xff09; 3. 缓存回收策略3.1 基于容量的回收&…

使用jstack排查CPU飙升的问题记录

最近&#xff0c;看到短视频传播了一个使用jstack来协助排查CPU飙升的案例。我也是比较感兴趣&#xff0c;参考了视频博主的流程&#xff0c;自己做了下对应案例的实战演练&#xff0c;在此&#xff0c;想做一下&#xff0c;针对相关问题模拟与排查演练的实战过程记录。 案例中…

Sql Server 中常用语句

1.创建用户数据库 --创建数据库 use master --切换到master数据库 go-- 终止所有与SaleManagerDB数据库的连接 alter database SaleManagerDB set single_user with rollback immediate goif exists (select * from sysdatabases where nameSaleManagerDB) drop database Sal…

联通专线赋能,亿林网络裸金属服务器:中小企业 IT 架构升级优选方案

在当今数字化飞速发展的时代&#xff0c;中小企业面临着日益增长的业务需求与复杂多变的市场竞争环境。如何构建高效、稳定且具性价比的 IT 架构&#xff0c;成为众多企业突破发展瓶颈的关键所在。而亿林网络推出的 24 核 32G 裸金属服务器&#xff0c;搭配联通专线的千兆共享带…

LangChain核心之Runnable接口底层实现

导读&#xff1a;作为LangChain框架的核心抽象层&#xff0c;Runnable接口正在重新定义AI应用开发的标准模式。这一统一接口设计将模型调用、数据处理和API集成等功能封装为可复用的逻辑单元&#xff0c;通过简洁的管道符语法实现复杂任务的声明式编排。 对于面临AI应用架构选择…

CSP严格模式返回不存在的爬虫相关文件

文章目录 说明示例&#xff08;返回404&#xff09;示例&#xff08;创建CSP例外&#xff09; 说明 日期&#xff1a;2025年6月4日。 CSP严格模式是default-src none&#xff0c;但有些web应用中&#xff0c;在爬虫相关文件不存在的情况下&#xff0c;依旧返回了对应文件&…

DeviceNET从站转EtherNET/IP主站在盐化工行业的创新应用

在工业自动化飞速发展的今天&#xff0c;盐化工行业也在积极探索智能化升级的路径。其中&#xff0c;设备之间的高效通信与协同工作成为了提升生产效率和质量的关键。而JH-DVN-EIP疆鸿智能DeviceNET从站转EtherNET/IP主站的技术应用&#xff0c;为盐化工行业带来了全新的解决方…

安装 Nginx

个人博客地址&#xff1a;安装 Nginx | 一张假钞的真实世界 对于 Linux 平台&#xff0c;Nginx 安装包 可以从 nginx.org 下载。 Ubuntu: 版本Codename支持平台12.04precisex86_64, i38614.04trustyx86_64, i386, aarch64/arm6415.10wilyx86_64, i386 在 Debian/Ubuntu 系统…

默认网关 -- 负责转发数据包到其他网络的设备(通常是路由器)

✅ 默认网关概括说明&#xff1a; 默认网关&#xff08;Default Gateway&#xff09;是网络中一台负责转发数据包到其他网络的设备&#xff08;通常是路由器&#xff09;。当一台主机要访问不在本地子网内的设备时&#xff0c;会将数据包发给默认网关&#xff0c;由它继续转发…

cv::FileStorage用法

cv::FileStorage 是 OpenCV 中的一个类&#xff0c;用于读取和写入结构化数据&#xff08;如 YAML、XML、JSON&#xff09;。它非常适合保存和加载诸如&#xff1a; 相机内参&#xff08;K、D&#xff09; 位姿&#xff08;R、T&#xff09; IMU 数据 配置参数 向量、矩阵、…

WebFuture:启动服务提示Job webfuture.service/start failed with result ‘dependency‘处理办法

问题分析&#xff1a; 当出现 Job webfuture.service/start failed with result dependency. 这样的错误提示时&#xff0c;通常意味着 webfuture.service 这个服务在启动时因为依赖关系的问题而未能成功启动 解决办法&#xff1a; 原因分析&#xff1a; webfuture.service 可…

Java 大视界 -- Java 大数据机器学习模型在遥感图像变化检测中的应用与改进(235)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也期待你毫无保留地分享独特见解,愿我们于此携手成长,共赴新程!💖 全网…

HarmonyOS运动开发:精准估算室内运动的距离、速度与步幅

##鸿蒙核心技术##运动开发##Sensor Service Kit&#xff08;传感器服务&#xff09;# 前言 在室内运动场景中&#xff0c;由于缺乏 GPS 信号&#xff0c;传统的基于卫星定位的运动数据追踪方法无法使用。因此&#xff0c;如何准确估算室内运动的距离、速度和步幅&#xff0c;…

商品模块中的多规格设计:实现方式与电商/ERP系统的架构对比

在商品管理系统中&#xff0c;多规格设计&#xff08;Multi-Specification Product Design&#xff09;是一个至关重要但又极具挑战性的领域。无论是面向消费者的电商系统&#xff0c;还是面向企业管理的ERP系统&#xff0c;对商品规格的处理方式直接影响库存管理、订单履约、数…

HTML 等价字符引用:系统化记忆指南

HTML 等价字符引用:系统化记忆指南 在 HTML 中,字符引用(Character Entity References)用于表示保留字符或特殊符号。我将提供一个系统化的方法来记忆这些重要实体,并解释它们的实际应用。 什么是等价字符引用? HTML 字符引用有两种形式: 命名实体:&entity_name…

Java 线程池原理详解

Java 线程池原理详解 一、引言 在高并发场景下&#xff0c;频繁地创建与销毁线程将带来极大的性能开销。为了提升资源复用性与程序响应速度&#xff0c;Java 提供了线程池机制&#xff08;java.util.concurrent 包&#xff09;。线程池通过复用线程、控制线程数量、任务排队管…

Mybatis入门到精通

一&#xff1a;什么是Mybatis 二&#xff1a;Mybatis就是简化jdbc代码的 三&#xff1a;Mybatis的操作步骤 1&#xff1a;在数据库中创建一个表&#xff0c;并添加数据 我们这里就省略了 2&#xff1a;Mybatis通过maven来导入坐标&#xff08;jar包&#xff09; 3&#xff1a…