Tencent is pleased to support the open source community by making RapidJSON available.
Copyright (C) 2015 THL A29 Limited, a Tencent company, and Milo Yip.
Linux | Windows | Coveralls |
---|---|---|
RapidJSON 是一个 C++ 的 JSON 解析器及生成器。它的灵感来自 RapidXml。
strlen()
相比。可支持 SSE2/SSE4.2 加速。"\u0000"
(空字符)。在 这里 可读取更多特点。
JSON(JavaScript Object Notation)是一个轻量的数据交换格式。RapidJSON 应该完全遵从 RFC7159/ECMA-404,并支持可选的放宽语法。 关于 JSON 的更多信息可参考:
Value
的内存开销从 24 字节至 16 字节。其他改动请参考 change log.
RapidJSON 是跨平台的。以下是一些曾测试的平台/编译器组合:
用户也可以在他们的平台上生成及执行单元测试。
RapidJSON 是只有头文件的 C++ 库。只需把 include/rapidjson
目录复制至系统或项目的 include 目录中。
RapidJSON 依赖于以下软件:
生成测试及例子的步骤:
git submodule update --init
去获取 thirdparty submodules (google test)。build
目录。build
目录下执行 cmake ..
命令以设置生成。Windows 用户可使用 cmake-gui 应用程序。make
。成功生成后,你会在 bin
的目录下找到编译后的测试及例子可执行文件。而生成的文档将位于 build 下的 doc/html
目录。要执行测试,请在 build 下执行 make test
或 ctest
。使用 ctest -V
命令可获取详细的输出。
我们也可以把程序库安装至全系统中,只要在具管理权限下从 build 目录执行 make install
命令。这样会按系统的偏好设置安装所有文件。当安装 RapidJSON 后,其他的 CMake 项目需要使用它时,可以通过在 CMakeLists.txt
加入一句 find_package(RapidJSON)
。
此简单例子解析一个 JSON 字符串至一个 document (DOM),对 DOM 作出简单修改,最终把 DOM 转换(stringify)至 JSON 字符串。
注意此例子并没有处理潜在错误。
下图展示执行过程。
还有许多 例子 可供参考:
Reader
解析 JSON 时,打印所有 SAX 事件。PrettyWriter
。JsonxWriter
,它能把 SAX 事件写成 JSONx(一种 XML)格式。这个例子是把 JSON 输入转换成 JSONx 格式的命令行工具。AsyncDocumentParser
类使用 C++ 线程来逐段解析 JSON。Document
。