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

在c++开发中,处理XML文件常用于配置读取、数据交换等场景。由于C++标准库没有内置XML支持,开发者通常依赖第三方库来解析和生成XML。本文介绍几种常用的C++ XML解析库,并给出基础用法示例,帮助你快速上手读取XML文件。
pugixml:轻量高效,推荐首选
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-2 是 TinyXML 的改进版,更少内存占用,更清晰的API设计,适合中小型项目。
立即学习“C++免费学习笔记(深入)”;
- API简单,学习成本低
- 仅需几个源文件,易于集成
- 不支持XPath,需手动遍历节点
基本用法:
#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:极速解析,适用于性能敏感场景
rapidxml 是一个基于模板的XML解析库,以极快的解析速度著称,但会修改原始XML字符串(原地解析),使用时需注意。
注意: rapidxml 要求XML内容为可修改的字符数组(如 char[]),不能是 const 字符串。
选择建议
根据项目需求选择合适的库:
- 追求简洁和功能全面 → 选 pugixml
- 项目小、想快速上手 → 选 tinyxml-2
- 对性能要求极高 → 考虑 rapidxml
基本上就这些。实际使用中,建议优先尝试 pugixml,它在易用性、性能和功能之间取得了良好平衡。集成时只需把头文件加入项目,无需额外构建步骤,非常方便。