C++如何解析JSON数据_C++常用JSON库RapidJSON与nlohmann使用

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

在C++中处理JSON数据,通常依赖第三方库来完成解析与生成。由于标准C++不原生支持JSON,开发者常使用成熟的开源库来简化操作。其中,RapidJSONnlohmann::json 是两个广泛使用的JSON库,各有特点,适用于不同场景。

1. RapidJSON:高性能、低开销的JSON库

RapidJSON 是由腾讯开发的C++ JSON库,以速度快、内存占用低著称,适合对性能要求较高的场景。它采用头文件形式,无需编译,集成方便。

使用步骤:

  • 包含头文件#include "rapidjson/document.h"
  • 使用 rapidjson::Document 解析JSON字符串
  • 通过键访问值,支持数组、对象嵌套

示例代码:

#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 类型直接解析和操作

示例代码:

#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)引入,避免手动管理依赖。