在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#include "rapidjson/document.h" #include "rapidjson/stringbuffer.h" #include "rapidjson/writer.h" int main() { const char* json = R"({ "name": "Alice", "age": 25, "hobbies": ["reading", "coding"] })";
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::json类型直接解析和操作示例代码:
立即学习“C++免费学习笔记(深入)”;
#include#include using json = nlohmann::json;
int main() { std::string json_str = R"({ "name": "Bob", "age": 30, "skills": ["C++", "Python"], "address": { "city": "Shanghai", "zip": "200000" } })";
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)引入,避免手动管理依赖。









