C++怎么解析JSON文件_C++ JSON解析方法与第三方库使用示例

C++中解析JSON需借助第三方库,常用库有jsoncpp、nlohmann/json和rapidjson。1. jsoncpp成熟稳定,通过Json::Value解析文件并访问字段;2. nlohmann/json语法简洁,类似Python字典操作,仅需包含头文件即可使用;3. rapidjson性能优异,支持SAX和DOM模式,适合高性能场景。选择依据项目需求:稳定性选jsoncpp,开发效率选nlohmann,性能优先选rapidjson。

在C++中解析JSON文件没有像Python或JavaScript那样的原生支持,但可以通过引入轻量级、高效的第三方库来实现。常用的C++ JSON解析库包括 jsoncppnlohmann/json(也叫JSON for Modern C++)和 rapidjson。这些库各有特点,可以根据项目需求选择。

1. 使用 jsoncpp 解析 JSON 文件

jsoncpp 是一个成熟且广泛使用的C++库,支持读取、写入和操作JSON数据。

安装方法(Ubuntu/Debian):

sudo apt-get install libjsoncpp-dev

示例代码:

#include iostream>
#include
#include stream>

int main() {
    std::ifstream file("config.json");
    Json::Value root;
    Json::CharReaderBuilder builder;
    std::string errs;

    if (!parseFromStream(builder, file, &root, &errs)) {
        std::cerr         return 1;
    }

    std::cout     std::cout
    return 0;
}

编译命令:

g++ -o parse_json parse_json.cpp -ljsoncpp

2. 使用 nlohmann/json(现代C++风格)

nlohmann/json 提供简洁直观的API,使用体验接近Python字典操作,适合现代C++项目。

获取方式: 头文件仅需下载 json.hpp 或通过vcpkg/conan安装。

示例代码:

#include
#include
#include
#include "json.hpp"

using json = nlohmann::json;

int main() {
    std::ifstream file("data.json");
    std::stringstream buffer;
    buffer     json j = json::parse(buffer.str());

    std::cout     std::cout
    // 遍历数组
    for (const auto& hobby : j["hobbies"]) {
        std::cout     }

    return 0;
}

该库无需编译依赖,只需包含头文件即可使用,非常适合快速开发。

3. 使用 rapidjson 实现高性能解析

rapidjson 是腾讯开源的C++ JSON库,以极快的解析速度著称,适用于对性能要求高的场景。

特点: 零依赖、内存占用低、支持SAX和DOM两种解析模式。

示例代码(DOM方式):

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

using namespace rapidjson;

int main() {
    std::ifstream file("data.json");
    std::stringstream buffer;
    buffer     std::string jsonStr = buffer.str();

    Document doc;
    doc.Parse(jsonStr.c_str());

    if (doc.HasParseError()) {
        std::cerr         return 1;
    }

    if (doc.HasMember("name") && doc["name"].IsString()) {
        std::cout     }

    return 0;
}

注意:rapidjson不自带文件流读取功能,需自行加载为字符串。

常见问题与建议

解析JSON时常见问题包括文件路径错误、格式非法、字段缺失等。建议在实际项目中加入异常处理机制。

  • 检查文件是否成功打开
  • 验证JSON结构是否符合预期
  • 访问字段前判断是否存在及类型是否正确
  • 对于嵌套结构,逐层解析避免越界访问

基本上就这些。选择哪个库取决于你的项目风格和性能需求:jsoncpp 稳定通用,nlohmann/json 写法优雅,rapidjson 性能突出。根据实际情况选用即可。