0

0

C++ 怎么读取ini配置文件 C++ GetPrivateProfileString用法详解【配置】

尼克

尼克

发布时间:2026-01-27 11:24:41

|

252人浏览过

|

来源于php中文网

原创

GetPrivateProfileString不推荐在新项目中使用,因其是遗留API,存在线程不安全、不支持Unicode路径、无法处理注释等缺陷;常见读不到值的原因是路径非绝对、编码不匹配或空格敏感。

c++ 怎么读取ini配置文件 c++ getprivateprofilestring用法详解【配置】

Windows 平台下,GetPrivateProfileString 是能用,但不推荐在新项目中直接依赖它读取 INI 文件。 它是 Win32 API 的遗留接口,行为隐晦、线程不安全、不支持 Unicode 路径(除非用 GetPrivateProfileStringW)、无法处理注释或嵌套节,且在 Windows 10/11 的某些沙盒或 UWP 兼容模式下可能被限制或失效。

为什么 GetPrivateProfileString 经常读不到值?

常见原因不是代码写错,而是环境或路径问题:

  • lpFileName 必须是**绝对路径**,相对路径会按当前进程工作目录查找,而该目录往往不是你预期的位置(比如 VS 调试时默认是项目根目录,而非可执行文件所在目录)
  • 如果传入的是窄字符字符串(GetPrivateProfileStringA),而 INI 文件实际是 UTF-8 编码(无 BOM),则中文会乱码;Windows 原生只认 ANSI 或 UTF-16 LE(带 BOM)
  • 节名(lpAppName)和键名(lpKeyName)区分大小写吗?答案是:**不区分**,但空格敏感——"Section ""Section" 被视为不同节
  • 若返回值为 0,不代表没读到,可能是键存在但值为空字符串;需检查缓冲区首字节是否为 '\0',而非只看返回长度

GetPrivateProfileStringW 的正确调用姿势

用宽字符版本才能可靠处理中文路径和 Unicode 内容。关键点:

  • 确保 INI 文件保存为 UTF-16 LE(记事本“另存为”可选),或至少是系统默认 ANSI 编码(如 GBK)
  • 缓冲区必须用 wchar_t 类型,且大小包含结尾的 L'\0'
  • 默认值参数(lpDefault)也必须是 LPCWSTR,不能传 "none" 这样的窄字符串字面量

示例:

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

阿里妈妈·创意中心
阿里妈妈·创意中心

阿里妈妈营销创意中心

下载
wchar_t buffer[256] = {0};
DWORD len = GetPrivateProfileStringW(
    L"database",     // 节名
    L"host",         // 键名
    L"127.0.0.1",    // 默认值(宽字符串!)
    buffer,           // 输出缓冲区
    _countof(buffer), // 缓冲区长度(含 \0)
    L"C:\\app\\config.ini" // 绝对路径,宽字符串
);
if (len == 0 || buffer[0] == L'\0') {
    // 未找到键,或值为空,此时 buffer 会被设为 lpDefault 内容
}

替代方案比硬刚 API 更省心

现代 C++ 项目建议绕过 Win32 INI API,改用轻量级第三方库或自行解析:

  • inih(single-header):纯 C,无依赖,支持 UTF-8,可轻松集成;ini_parse() 回调方式简单清晰
  • jsoncppnlohmann/json:把配置转成 JSON,开发调试更直观,IDE 支持好,还能用 schema 校验
  • 自己用 std::wifstream + std::getline 解析:适合格式极简、无复杂转义的场景;注意跳过 ; 开头的注释行和空行

如果你只是想快速验证某段 INI 是否被正确加载,用 PowerShell 一行就能测:Get-Content .\config.ini 看编码和结构,比反复编译 C++ 更快定位问题。

真正麻烦的从来不是函数怎么写,而是 INI 文件放在哪、用什么编码、谁在什么时候修改过它——这些信息不会出现在编译错误里。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c++和c语言的区别有哪些
c++和c语言的区别有哪些

c++和c语言的区别:1、面向对象编程(OOP)支持不同;2、新增特性不同;3、标准库不同;4、编译方式不同;5、命名空间不同等等。想了解更多c++的相关内容,可以阅读本专题下面的文章。

258

2024.03.14

c++和python学习顺序推荐
c++和python学习顺序推荐

一般建议先学习C++,再学习Python,因为这样可以逐步从较为底层的编程语言向更高级的语言过渡。想了解更多python的相关内容,可以阅读本专题下面的文章。

423

2024.03.14

python和c++学习性价比分析
python和c++学习性价比分析

Python易于学习,广泛应用于Web开发、数据科学和人工智能等领域,但性能较低。C语言性能高,适用于对性能要求较高的场景,如游戏开发和系统编程,但学习曲线陡峭,错误处理复杂。想了解更多python的相关内容,可以阅读本专题下面的文章。

103

2024.03.14

c语言和c++一样吗
c语言和c++一样吗

c语言和c++是两种不同的编程语言,虽然有相似之处,但存在显著差异。c语言专注于过程式编程和系统级开发,以简洁、高效著称。c++作为c语言的超集,引入了面向对象编程,增强了代码组织和管理能力,但学习曲线也更陡峭。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

135

2024.03.14

c语言和c++先学哪个好
c语言和c++先学哪个好

初学者选择学习c语言还是c++语言,需要根据个人学习目标、背景以及编程兴趣和预期应用方向来决定。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

101

2024.03.14

c语言和c++的区别和联系
c语言和c++的区别和联系

c语言和c++是计算机科学领域应用广泛的编程语言。虽然它们有着相似的基础,但它们在语言类型、语法功能和内存管理方面存在着显著差异。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

123

2024.03.14

c++软件中文更改教程
c++软件中文更改教程

对于 ide,可通过打开设置,找到语言设置,选择中文,并保存更改。对于非 ide 应用程序,可查找设置或选项,选择语言设置,更改为中文,并保存更改。想了解更多c++的相关内容,可以阅读本专题下面的文章。

303

2024.03.21

python和java和c++学习性价比分析
python和java和c++学习性价比分析

Python以其易学性、丰富的库和活跃的社区而著称,适合数据科学、人工智能和Web开发。Java以其跨平台性、企业级应用开发和Android应用开发而闻名。C++以其底层控制能力、高效性能和游戏开发而著称。选择哪种语言取决于个人兴趣、职业方向和特定需求。想了解更多python和java和c++的相关内容,可以阅读本专题下面的文章。

335

2024.03.22

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

1

2026.01.27

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.5万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

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

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