在C++中处理JSON需借助第三方库,RapidJSON性能高、内存占用低,适合高性能场景;nlohmann::json语法简洁、易用性强,适合快速开发;选择应基于性能需求与开发效率权衡。

在C++中处理JSON数据,通常依赖第三方库来完成解析与生成。由于标准C++不原生支持JSON,开发者常使用成熟的开源库来简化操作。其中,RapidJSON 和 nlohmann::json 是两个广泛使用的JSON库,各有特点,适用于不同场景。
1. RapidJSON:高性能、低开销的JSON库
RapidJSON 是由腾讯开发的C++ JSON库,以速度快、内存占用低著称,适合对性能要求较高的场景。它采用头文件形式,无需编译,集成方便。
使用步骤:
本文档主要讲述的是使用JSON进行网络数据交换传输;JSON(JavaScript ObjectNotation)是一种轻量级的数据交换格式,易于阅读和编写,同时也易于机器解析和生成,非常适合于服务器与客户端的交互。JSON采用与编程语言无关的文本格式,但是也使用了类C语言的习惯,这些特性使JSON成为理想的数据交换格式。 和 XML 一样,JSON 也是基于纯文本的数据格式。由于 JSON 天生是为 JavaScript 准备的,因此,JSON的数据格式非常简单,您可以用 JSON 传输一个简单的 St
- 包含头文件:
#include "rapidjson/document.h" - 使用
rapidjson::Document解析JSON字符串 - 通过键访问值,支持数组、对象嵌套
示例代码:
立即学习“C++免费学习笔记(深入)”;
#include <iostream>
#include "rapidjson/document.h"
#include "rapidjson/stringbuffer.h"
#include "rapidjson/writer.h"
<p>int main() {
const char* json = R"({
"name": "Alice",
"age": 25,
"hobbies": ["reading", "coding"]
})";</p><pre class="brush:php;toolbar:false;">rapidjson::Document doc;
doc.Parse(json);
if (doc.HasParseError()) {
std::cout << "JSON解析失败" << std::endl;
return -1;
}
if (doc.HasMember("name") && doc["name"].IsString()) {
std::cout << "姓名: " << doc["name"].GetString() << std::endl;
}
if (doc.HasMember("age") && doc["age"].IsInt()) {
std::cout << "年龄: " << doc["age"].GetInt() << std::endl;
}
if (doc.HasMember("hobbies") && doc["hobbies"].IsArray()) {
auto& hobbies = doc["hobbies"];
for (int i = 0; i < hobbies.Size(); ++i) {
std::cout << "爱好: " << hobbies[i].GetString() << std::endl;
}
}
return 0;}
优点: 性能高,适合大型JSON或嵌入式环境
缺点: API较底层,写法略显繁琐,需手动检查类型
2. nlohmann::json:现代C++风格的JSON库
nlohmann JSON 库以易用性、现代C++语法支持著称,使用方式接近Python字典,非常适合快速开发和中小型项目。
使用步骤:
- 下载单头文件版本(json.hpp)
- 包含头文件:
#include <nlohmann></nlohmann> - 使用
nlohmann::json类型直接解析和操作
示例代码:
立即学习“C++免费学习笔记(深入)”;
#include <iostream>
#include <nlohmann/json.hpp>
<p>using json = nlohmann::json;</p><p>int main() {
std::string json_str = R"({
"name": "Bob",
"age": 30,
"skills": ["C++", "Python"],
"address": {
"city": "Shanghai",
"zip": "200000"
}
})";</p><pre class="brush:php;toolbar:false;">json j = json::parse(json_str);
std::cout << "姓名: " << j["name"] << std::endl;
std::cout << "年龄: " << j["age"] << std::endl;
for (auto& skill : j["skills"]) {
std::cout << "技能: " << skill << std::endl;
}
std::cout << "城市: " << j["address"]["city"] << std::endl;
return 0;}
优点: 语法简洁,支持自动类型转换,兼容STL容器
缺点: 相比RapidJSON稍慢,内存占用略高
3. 如何选择合适的库?
根据项目需求决定使用哪个库:
- 追求极致性能、处理大量JSON数据(如日志系统、网络服务),推荐 RapidJSON
- 希望代码简洁、开发效率高,尤其是原型开发或小型项目,推荐 nlohmann::json
- RapidJSON 支持SAX解析,适合流式处理;nlohmann 更适合DOM式操作
- 两者都支持C++11及以上,易于集成到现代C++项目中
基本上就这些。两个库都能很好地完成JSON解析任务,选择时更应关注团队习惯和项目实际需求。集成时建议通过包管理器(如vcpkg、conan)引入,避免手动管理依赖。









