答案:C++中常用TinyXML-2、pugixml和Xerces-C++解析XML;TinyXML-2轻量易用,适合小型项目;pugixml性能高,支持XPath;Xerces-C++功能完整,适用于企业级应用。
在C++中解析XML文件没有像Python或Java那样的内置库支持,但可以通过第三方库高效实现。常用的XML解析方式包括使用TinyXML、pugixml、Xerces-C++等库。下面介绍几种主流的C++ XML解析方法及其实现思路。
TinyXML-2是一个简单、小巧的C++ XML解析库,适合中小型项目。它以DOM(文档对象模型)方式加载整个XML文件到内存,便于遍历和修改。
基本使用步骤:
示例代码:
#include "tinyxml2.h" #includeusing namespace tinyxml2;
int main() { XMLDocument doc; if (doc.LoadFile("example.xml") != XML_SUCCESS) { std::cerr << "无法加载文件" << std::endl; return -1; }
XMLElement* root = doc.FirstChildElement("root"); if (root) { XMLElement* child = root->FirstChildElement("person"); while (child) { const char* name = child->Attribute("name"); const char* ageStr = child->Attribute("age");std::cout << "姓名: " << name << ", 年龄: " << ageStr << std::endl; child = child->NextSiblingElement("person"); } } return 0;
}
pugixml以性能高、API简洁著称,支持DOM和XPath查询,适合对性能要求较高的场景。
特点:
示例代码:
#include "pugixml.hpp" #includeint main() { pugi::xml_document doc; if (!doc.load_file("example.xml")) { std::cerr << "加载失败" << std::endl; return -1; }
pugi::xml_node root = doc.child("root"); for (pugi::xml_node person : root.children("person")) { std::cout << "姓名: " << person.attribute("name").value() << ", 年龄: " << person.attribute("age").value() << std::endl; } return 0;}
Xerces-C++是Apache推出的重量级XML解析库,支持SAX和DOM两种解析模式,符合W3C标准,适用于大型企业级应用。
适用场景:
SAX模式为事件驱动,内存占用低;DOM模式便于随机访问,但消耗更多内存。
根据项目需求选择合适的库:
基本上就这些常见方式,引入对应库后,解析XML就是遍历节点、提取属性和文本的过程,不复杂但容易忽略错误处理和编码问题。