0

0

c++如何读取配置文件的值_c++解析ini配置文件方法【实战】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-02-11 15:11:02

|

410人浏览过

|

来源于php中文网

原创

INI文件读取本质是键值对解析,C++无标准库支持,常用inih库(单头文件、回调式解析)或手写解析器,Windows下可用GetPrivateProfileString但需注意编码、路径和缓冲区问题。

c++如何读取配置文件的值_c++解析ini配置文件方法【实战】

INI 文件读取本质是键值对解析,C++ 没有标准库支持,必须借助第三方或手写解析器

标准 C++ 不提供 GetPrivateProfileString 或类似 INI 解析接口,Windows API 的 GetPrivateProfileString 仅限 Windows 平台且依赖 kernel32.lib,跨平台项目中基本不可用。多数实际项目选择轻量级第三方库(如 inih)或封装简单的行扫描逻辑——关键不是“能不能读”,而是“要不要支持节嵌套、注释、转义、空格容忍”等细节。

用 inih 库读取 INI 最省心,头文件即用,无需编译

inih 是纯 C 实现的单头文件库(ini.h + ini.c),C++ 项目可直接 #include 使用。它不构建内存结构,而是通过回调函数逐行通知解析结果,内存占用极低,适合嵌入式或配置项较少的场景。

典型用法:

// callback 函数
int handler(void* user, const char* section, const char* name, const char* value) {
    if (strcmp(section, "database") == 0 && strcmp(name, "port") == 0) {
        *(int*)user = atoi(value); // 假设 user 指向 int port;
    }
    return 1; // 继续解析
}

// 调用 int port = 0; ini_parse("config.ini", handler, &port);

  • ini_parse 第二个参数是回调函数,第三个是传给它的上下文指针,适合传递多个变量地址(例如用 struct 封装)
  • 不支持 [section:sub] 这类嵌套节名,遇到未知格式会跳过整行
  • 注释以 ;# 开头,会被自动忽略;键名前后空格被保留,值前后空格默认不 trim(需手动 strtrim

Windows 下用 GetPrivateProfileString 需注意路径和 Unicode 问题

若只面向 Windows 桌面程序,且配置文件路径固定,可用系统 API 快速读取,但容易踩坑:

立即学习C++免费学习笔记(深入)”;

AI Agent
AI Agent

AIAgent.app 是一个可以让你使用AI代理来完成各种任务的网站,有效提升创造生产力

下载
  • GetPrivateProfileString 默认按 ANSI 编码读取,若 INI 文件是 UTF-8 无 BOM,中文会乱码;建议改用 GetPrivateProfileStringW 并确保文件保存为 UTF-16 LE(记事本另存为时可选)
  • 路径必须是绝对路径或相对于当前工作目录;相对路径在 IDE 调试时可能指向项目根目录,而发布后指向 exe 所在目录,建议用 GetModuleFileName 拼出配置文件全路径
  • 缓冲区大小必须足够,否则截断;返回值是实际复制的字符数(不含 \0),不能直接当字符串长度用

示例:

TCHAR buffer[256] = {0};
GetPrivateProfileString(_T("network"), _T("host"), _T("localhost"), 
                        buffer, _countof(buffer), _T("app.ini"));
// buffer 现在含 host 值,注意末尾有 \0

手写简易解析器要防住换行、空行、注释和等号位置异常

如果项目不允许引入外部依赖,又只需读几个固定 key,手写解析器比想象中更可靠,但必须处理这些边界:

  • 一行含多个 =(如 url=http://a=b/c?d=e):应取第一个等号左边为 key,右边全部为 value
  • key 或 value 包含空格(如 log path = D:\my logs\):不能简单 strtok(" =", " \t"),需手动找首个非空白后的 =
  • 注释在行尾(timeout=30 ; seconds):找到 = 后,再跳过右侧空格,检查是否以 ;# 开头
  • 空行、纯空格行、只有注释的行:跳过,不要当作 section 或 key

核心逻辑片段(C++17):

std::string line;
while (std::getline(file, line)) {
    auto pos = line.find_first_not_of(" \t\r\n");
    if (pos == std::string::npos || line[pos] == ';' || line[pos] == '#') continue;
    if (line[pos] == '[' && line.find(']', pos) != std::string::npos) {
        // 解析 section
    } else if (auto eq = line.find('='); eq != std::string::npos) {
        std::string key = trim(line.substr(pos, eq - pos));
        std::string val = trim(line.substr(eq + 1));
        // 去掉 val 尾部的 ; 注释
        if (auto cmt = val.find_first_of(";#"); cmt != std::string::npos) {
            val.erase(cmt);
        }
        config[key] = trim(val);
    }
}

真正麻烦的从来不是“读到值”,而是“下次 INI 格式微调后,你的解析逻辑是否还健壮”。尤其当配置由运维手工修改时,多一个空格、少一个引号、错位的分号,都可能让程序静默读错值。宁可多花十分钟加几行 trim 和容错判断,也不要赌用户一定按文档格式写。

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

488

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

214

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1547

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

637

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

841

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

813

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

184

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

87

2025.08.07

Rust异步编程与Tokio运行时实战
Rust异步编程与Tokio运行时实战

本专题聚焦 Rust 语言的异步编程模型,深入讲解 async/await 机制与 Tokio 运行时的核心原理。内容包括异步任务调度、Future 执行模型、并发安全、网络 IO 编程以及高并发场景下的性能优化。通过实战示例,帮助开发者使用 Rust 构建高性能、低延迟的后端服务与网络应用。

1

2026.02.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.2万人学习

C 教程
C 教程

共75课时 | 4.7万人学习

C++教程
C++教程

共115课时 | 17.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号