pugixml因轻量高效且支持DOM和XPath,是C++处理XML的首选库;tinyxml-2适合初学者,API简单易用;rapidxml解析速度快,适用于性能敏感场景;建议优先使用pugixml。

在C++开发中,处理XML文件常用于配置读取、数据交换等场景。由于C++标准库没有内置XML支持,开发者通常依赖第三方库来解析和生成XML。本文介绍几种常用的C++ XML解析库,并给出基础用法示例,帮助你快速上手读取XML文件。
pugixml 是一个轻量级、高性能的C++ XML处理库,支持DOM和XPath,语法简洁,文档清晰,适合大多数项目使用。
安装与引入: 下载 pugixml 的头文件(pugixml.hpp 和 pugiconfig.hpp)并放入项目目录。
基础读取示例:
#include "pugixml.hpp"
#include <iostream>
<p>int main() {
pugi::xml_document doc;
pugi::xml_parse_result result = doc.load_file("config.xml");</p><pre class="brush:php;toolbar:false;">if (!result) {
std::cout << "XML解析失败: " << result.description() << std::endl;
return -1;
}
// 获取根节点
pugi::xml_node root = doc.child("config");
for (pugi::xml_node node : root.children("item")) {
std::string name = node.attribute("name").value();
std::string value = node.text().get();
std::cout << "Name: " << name << ", Value: " << value << std::endl;
}
return 0;}
tinyxml-2 是 TinyXML 的改进版,更少内存占用,更清晰的API设计,适合中小型项目。
立即学习“C++免费学习笔记(深入)”;
基本用法:
#include "tinyxml2.h"
#include <iostream>
<p>using namespace tinyxml2;</p><p>int main() {
XMLDocument doc;
XMLError result = doc.LoadFile("config.xml");
if (result != XML_SUCCESS) {
std::cout << "加载失败" << std::endl;
return -1;
}</p><pre class="brush:php;toolbar:false;">XMLElement* root = doc.FirstChildElement("config");
for (XMLElement* elem = root->FirstChildElement("item");
elem != nullptr; elem = elem->NextSiblingElement()) {
const char* name = elem->Attribute("name");
const char* value = elem->GetText();
std::cout << "Name: " << name << ", Value: " << value << std::endl;
}
return 0;}
rapidxml 是一个基于模板的XML解析库,以极快的解析速度著称,但会修改原始XML字符串(原地解析),使用时需注意。
注意: rapidxml 要求XML内容为可修改的字符数组(如 char[]),不能是 const 字符串。
根据项目需求选择合适的库:
基本上就这些。实际使用中,建议优先尝试 pugixml,它在易用性、性能和功能之间取得了良好平衡。集成时只需把头文件加入项目,无需额外构建步骤,非常方便。
以上就是C++如何读取XML文件_C++常用XML解析库推荐与基础用法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号