Xerces-C++ 是 Apache 提供的跨平台 C++ XML 解析库,支持 DOM、SAX 和 SAX2;Linux/macOS 推荐源码编译安装,Windows 推荐 vcpkg 管理;使用前需初始化,解析后须终止,链接时注意依赖和编译器标准一致。

Xerces-C++ 是 Apache 提供的跨平台 C++ XML 解析库,支持 DOM、SAX 和 SAX2 三种解析方式,广泛用于需要高性能、标准兼容 XML 处理的 C++ 项目中。安装和使用它需注意平台差异、构建方式及链接细节。
Linux/macOS 下编译安装 Xerces-C++
官方推荐从源码构建(预编译包较少且版本滞后):
- 下载源码:访问 https://xerces.apache.org/xerces-c/download.cgi,获取最新稳定版(如
xerces-c-3.2.4.tar.gz) -
解压后进入目录,执行标准 CMake 构建流程:
mkdir build && cd build
cmake -DCMAKE_INSTALL_PREFIX=/usr/local ..
make -j$(nproc)
sudo make install - 默认启用 ICU(国际化支持),若无需 Unicode 高级处理,可加
-DXERCES_USE_ICU=OFF减少依赖 - 安装后头文件在
/usr/local/include/xercesc/,库文件在/usr/local/lib/libxerces-c.so(Linux)或.dylib(macOS)
Windows 上使用预编译库或 vcpkg
推荐用 vcpkg 管理(省去手动编译和路径配置):
- 已安装 vcpkg 后,运行:
vcpkg install xerces-c:x64-windows(或x86-windows) - 在 CMakeLists.txt 中集成:
find_package(xerces_c CONFIG REQUIRED),然后target_link_libraries(your_target PRIVATE xerces_c::xerces_c) - 若手动使用预编译二进制(如官网提供的 Windows ZIP),需确保
bin/加入系统 PATH,lib/和include/正确配置到项目中,并注意运行时 DLL 与编译器(MSVC 版本、静态/动态 CRT)匹配
基础 DOM 解析示例(C++ 代码)
以下是最小可用 DOM 解析片段,读取 XML 文件并打印根元素名:
95Shop可以免费下载使用,是一款仿醉品商城网店系统,内置SEO优化,具有模块丰富、管理简洁直观,操作易用等特点,系统功能完整,运行速度较快,采用ASP.NET(C#)技术开发,配合SQL Serve2000数据库存储数据,运行环境为微软ASP.NET 2.0。95Shop官方网站定期开发新功能和维护升级。可以放心使用! 安装运行方法 1、下载软件压缩包; 2、将下载的软件压缩包解压缩,得到we
立即学习“C++免费学习笔记(深入)”;
- 包含头文件:
#include、#include、#include等 - 初始化 Xerces(必须在首次解析前调用):
XercesDOMParser* parser = new XercesDOMParser();前加XMLPlatformUtils::Initialize(); - 解析并获取文档:
parser->parse("test.xml"); DOMDocument* doc = parser->getDocument(); - 提取根元素:
DOMElement* root = doc->getDocumentElement();,再用XMLString::transcode(root->getTagName())转为 C 字符串输出 - 最后清理:
XMLPlatformUtils::Terminate();,并释放 parser 和 doc(DOM 文档由 parser 管理,通常不手动 delete)
链接与编译注意事项
常见链接失败多因遗漏依赖或符号未导出:
- Linux/macOS 编译时加:
-lxerces-c -lpthread -ldl(部分系统还需-lstdc++) - 确保编译器标准一致(Xerces-C++ 默认用 C++11,项目也需开启
-std=c++11或更高) - 若出现
undefined reference to 'XMLPlatformUtils::Initialize()',说明链接库顺序错误或未链接-lxerces-c - Windows 下若用 MSVC 静态链接,需定义
XERCES_STATIC_LIBRARY宏;动态链接则确保运行时能找到xerces-c_3_2.dll









