17370845950

C++如何处理JSON数据?(常用库与代码示例)
C++处理JSON主流依赖第三方库,nlohmann/json最常用且轻量;支持解析、生成、文件读写及结构体自动映射;其他库如jsoncpp、Boost.PropertyTree、simdjson适用于不同场景。

用C++处理JSON数据,主流方式是借助第三方库,因为标准库不直接支持JSON解析与生成。最常用、轻量且易上手的是 nlohmann/json(头文件-only,无需编译);工业级项目中也会用到 jsoncppBoost.PropertyTree;高性能场景可考虑 simdjson。下面以 nlohmann/json 为主,给出典型用法和对比说明。

用 nlohmann/json 解析和生成 JSON

它语法接近现代C++,支持 STL 容器风格操作,自动推导类型,开发效率高。

  • 安装:只需把 json.hpp 头文件加入工程(或通过 vcpkg/conan 安装)
  • 解析字符串:json j = json::parse("{ \"name\": \"Alice\", \"age\": 30 }");
  • 访问字段:std::string name = j["name"]; int age = j["age"];(支持隐式类型转换)
  • 构建对象:json j2 = {{"name", "Bob"}, {"scores", {95, 87, 91}}};
  • 序列化为字符串:std::string s = j2.dump(2); // 缩进2格

读写 JSON 文件(nlohmann 示例)

实际项目中多数 JSON 数据来自或存入文件,需配合 使用。

  • 从文件读取:std::ifstream i("config.json"); json j; i >> j;
  • 写入文件:std::ofstream o("output.json"); o
  • 注意:读取前建议检查文件是否打开成功,解析时用 try-catch 捕获 json::parse_error

其他常用库简要对比

不同场景下可按需选择:

  • jsoncpp:C++11 以前较流行,API 稍冗长(如 root["data"].asInt()),需编译静态/动态库
  • Boost.PropertyTree:通用配置树,支持 JSON/XML/INI,但 JSON 支持较弱(不保留原始顺序、无数组语义)
  • simdjson:超高速解析(基于 SIMD 指令),适合 GB 级日志分析,但 API 较底层,不推荐新手直接使用

小技巧:结构体与 JSON 自动映射(nlohmann 扩展)

可通过宏定义实现结构体 ↔ JSON 的双向转换,避免手动赋值。

  • 定义结构体后加宏:NLOHMANN_DEFINE_TYPE_INTRUSIVE(Person, name, age, hobbies)
  • 然后直接:Person p = j.get();json j2 = p;
  • 要求成员为 public,或自定义非侵入式版本(用 NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE

基本上就这些。nlohmann/json 覆盖了绝大多数 C++ JSON 处理需求,简洁可靠;复杂协议或性能敏感场景再考虑其他方案。记得始终检查解析异常,别让非法 JSON 导致程序崩溃。