c++ 怎么处理JSON数据_c++解析与生成JSON数据的常见方法

推荐使用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容器和自定义类型

示例代码:

// 安装方式:vcpkg install nlohmann-json 或直接下载json.hpp
#include 
#include 

using json = nlohmann::json;

int main() { // 解析JSON字符串 std::string json_str = R"({"name": "Alice", "age": 30, "city": "Beijing"})"; json j = json::parse(json_str);

std::cout zuojiankuohaophpcnzuojiankuohaophpcn "Name: " zuojiankuohaophpcnzuojiankuohaophpcn j["name"] zuojiankuohaophpcnzuojiankuohaophpcn ", Age: " zuojiankuohaophpcnzuojiankuohaophpcn j["age"] zuojiankuohaophpcnzuojiankuohaophpcn "\n";

// 生成JSON
json output;
output["name"] = "Bob";
output["score"] = 95.5;
output["hobbies"] = {"reading", "coding"};

std::cout zuojiankuohaophpcnzuojiankuohaophpcn output.dump(4) zuojiankuohaophpcnzuojiankuohaophpcn std::endl; // 格式化输出,缩进4格

}

使用RapidJSON(高性能场景)

RapidJSON 是腾讯开源的C++ JSON库,强调性能和内存效率,适合对速度要求高的项目。

特点:
  • 支持SAX和DOM两种解析模式
  • 零依赖,可配置内存管理
  • 适用于嵌入式或服务端高频处理场景

示例代码:

#include 
#include "rapidjson/document.h"
#include "rapidjson/stringbuffer.h"
#include "rapidjson/writer.h"

using namespace rapidjson;

int main() { const char* json_str = R"({"user": "Tom", "active": true})";

Document doc;
doc.Parse(json_str);

if (doc.HasMember("user") && doc["user"].IsString()) {
    std::cout zuojiankuohaophpcnzuojiankuohaophpcn "User: " zuojiankuohaophpcnzuojiankuohaophpcn doc["user"].GetString() zuojiankuohaophpcnzuojiankuohaophpcn "\n";
}

// 生成JSON
StringBuffer buffer;
WriterzuojiankuohaophpcnStringBufferyoujiankuohaophpcn writer(buffer);
writer.StartObject();
writer.Key("id"); writer.Int(1001);
writer.Key("valid"); writer.Bool(true);
writer.EndObject();

std::cout zuojiankuohaophpcnzuojiankuohaophpcn buffer.GetString() zuojiankuohaophpcnzuojiankuohaophpcn std::endl;

}

使用JsonCpp(老牌稳定选择)

JsonCpp 是较早出现的C++ JSON库,广泛用于旧项目,API清晰,文档丰富。

适用情况:
  • 维护老系统或团队已有技术栈
  • C++98兼容需求

基本用法:

#include 
#include 

int main() { Json::Value root; Json::Reader reader;

std::string json_str = R"({"title": "C++ Guide", "pages": 250})";

if (reader.parse(json_str, root)) {
    std::cout zuojiankuohaophpcnzuojiankuohaophpcn "Title: " zuojiankuohaophpcnzuojiankuohaophpcn root["title"].asString() zuojiankuohaophpcnzuojiankuohaophpcn "\n";
    std::cout zuojiankuohaophpcnzuojiankuohaophpcn "Pages: " zuojiankuohaophpcnzuojiankuohaophpcn root["pages"].asInt() zuojiankuohaophpcnzuojiankuohaophpcn "\n";
}

// 构建JSON
Json::Value output;
output["status"] = "ok";
output["count"] = 10;

Json::FastWriter writer;
std::cout zuojiankuohaophpcnzuojiankuohaophpcn writer.write(output) zuojiankuohaophpcnzuojiankuohaophpcn std::endl;

}

如何选择合适的库?

根据项目需求做出合理选择:

  • 新项目、注重开发体验 → 推荐 nlohmann/json
  • 性能敏感、低延迟 → 选用 RapidJSON
  • 遗留系统或需兼容旧编译器 → 考虑 JsonCpp

基本上就这些。引入对应库后,读写JSON就能像操作对象一样自然。注意处理异常(如解析失败),并在生产环境中做必要的输入校验。