推荐使用nlohmann/json、rapidjson或jsoncpp处理c++中json数据:新项目首选nlohmann/json因其简洁现代的语法;高性能场景选用rapidjson,具备高效解析能力;老旧系统可选jsoncpp以兼容旧标准。

在C++中处理JSON数据通常依赖第三方库,因为标准库并不直接支持JSON解析与生成。以下是几种常见的方法和推荐使用的库,帮助你高效地解析和生成JSON数据。
使用nlohmann/json(现代C++首选)
nlohmann/json 是一个流行的单头文件库,专为现代C++(C++11及以上)设计,语法简洁直观,非常适合快速开发。
优点:- 无需编译,只需包含头文件
- API友好,支持类似JavaScript的对象访问语法
- 良好支持STL容器和自定义类型
示例代码:
本文档主要讲述的是使用JSON进行网络数据交换传输;JSON(JavaScript ObjectNotation)是一种轻量级的数据交换格式,易于阅读和编写,同时也易于机器解析和生成,非常适合于服务器与客户端的交互。JSON采用与编程语言无关的文本格式,但是也使用了类C语言的习惯,这些特性使JSON成为理想的数据交换格式。 和 XML 一样,JSON 也是基于纯文本的数据格式。由于 JSON 天生是为 JavaScript 准备的,因此,JSON的数据格式非常简单,您可以用 JSON 传输一个简单的 St
#include <iostream>
#include <nlohmann/json.hpp>
<p>using json = nlohmann::json;</p><p><span>立即学习</span>“<a href="https://pan.quark.cn/s/6e7abc4abb9f" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">C++免费学习笔记(深入)</a>”;</p><p>int main() {
// 解析JSON字符串
std::string json_str = R"({"name": "Alice", "age": 30, "city": "Beijing"})";
json j = json::parse(json_str);</p><pre class='brush:php;toolbar:false;'>std::cout << "Name: " << j["name"] << ", Age: " << j["age"] << "\n";
// 生成JSON
json output;
output["name"] = "Bob";
output["score"] = 95.5;
output["hobbies"] = {"reading", "coding"};
std::cout << output.dump(4) << std::endl; // 格式化输出,缩进4格}
使用RapidJSON(高性能场景)
RapidJSON 是腾讯开源的C++ JSON库,强调性能和内存效率,适合对速度要求高的项目。
特点:- 支持SAX和DOM两种解析模式
- 零依赖,可配置内存管理
- 适用于嵌入式或服务端高频处理场景
示例代码:
#include <iostream>
#include "rapidjson/document.h"
#include "rapidjson/stringbuffer.h"
#include "rapidjson/writer.h"
<p>using namespace rapidjson;</p><p>int main() {
const char* json_str = R"({"user": "Tom", "active": true})";</p><pre class='brush:php;toolbar:false;'>Document doc;
doc.Parse(json_str);
if (doc.HasMember("user") && doc["user"].IsString()) {
std::cout << "User: " << doc["user"].GetString() << "\n";
}
// 生成JSON
StringBuffer buffer;
Writer<StringBuffer> writer(buffer);
writer.StartObject();
writer.Key("id"); writer.Int(1001);
writer.Key("valid"); writer.Bool(true);
writer.EndObject();
std::cout << buffer.GetString() << std::endl;}
使用JsonCpp(老牌稳定选择)
JsonCpp 是较早出现的C++ JSON库,广泛用于旧项目,API清晰,文档丰富。
适用情况:- 维护老系统或团队已有技术栈
- C++98兼容需求
基本用法:
#include <json/json.h>
#include <iostream>
<p>int main() {
Json::Value root;
Json::Reader reader;</p><pre class='brush:php;toolbar:false;'>std::string json_str = R"({"title": "C++ Guide", "pages": 250})";
if (reader.parse(json_str, root)) {
std::cout << "Title: " << root["title"].asString() << "\n";
std::cout << "Pages: " << root["pages"].asInt() << "\n";
}
// 构建JSON
Json::Value output;
output["status"] = "ok";
output["count"] = 10;
Json::FastWriter writer;
std::cout << writer.write(output) << std::endl;}
如何选择合适的库?
根据项目需求做出合理选择:
- 新项目、注重开发体验 → 推荐 nlohmann/json
- 性能敏感、低延迟 → 选用 RapidJSON
- 遗留系统或需兼容旧编译器 → 考虑 JsonCpp
基本上就这些。引入对应库后,读写JSON就能像操作对象一样自然。注意处理异常(如解析失败),并在生产环境中做必要的输入校验。










