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

用C++处理JSON数据,主流方式是借助第三方库,因为标准库不直接支持JSON解析与生成。最常用、轻量且易上手的是 nlohmann/json(头文件-only,无需编译);工业级项目中也会用到 jsoncpp 或 Boost.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
其他常用库简要对比
不同场景下可按需选择:
动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包
立即学习“C++免费学习笔记(深入)”;
-
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 导致程序崩溃。









