使用nlohmann/json库实现C++对象序列化与反序列化:1. 引入json.hpp头文件;2. 定义User类并实现to_json和from_json方法;3. 调用dump()将对象转为JSON字符串,或通过构造函数解析JSON到对象。

在C++中实现对象的JSON序列化与反序列化,由于语言本身没有内置支持,需要借助第三方库或手动实现。目前最常用且高效的方法是使用成熟的JSON库配合自定义转换逻辑。
选择合适的JSON库
推荐使用以下流行且维护良好的C++ JSON库:
- nlohmann/json:头文件-only,使用简单,语法接近Python字典操作
- jsoncpp:老牌库,结构清晰,适合大型项目
- Boost.JSON:属于Boost生态,性能好,适合已使用Boost的项目
以 nlohmann/json 为例说明如何实现序列化与反序列化。
安装并引入nlohmann/json
该库为单头文件设计,可直接下载json.hpp包含到项目中,或通过包管理器安装(如vcpkg、conan)。
立即学习“C++免费学习笔记(深入)”;
示例代码引入方式:#include#include #include using json = nlohmann::json;
实现类的序列化与反序列化
假设有一个表示用户信息的类User:
class User {
public:
std::string name;
int age;
std::string email;
// 序列化:对象 → JSON
json to_json() const {
return json{
{"name", name},
{"age", age},
{"email", email}
};
}
// 反序列化:JSON → 对象
void from_json(const json& j) {
name = j.value("name", "");
age = j.value("age", 0);
email = j.value("email", "");
}
};
使用方式:
User user{"张三", 25, "zhangsan@example.com"};
// 序列化为JSON字符串
json j = user.to_json();
std::string json_str = j.dump(4); // 格式化输出,缩进4格
std::cout << json_str << std::endl;
输出结果:
{
"age": 25,
"email": "zhangsan@example.com",
"name": "张三"
}
从JSON字符串恢复对象:
json j2 = json::parse(json_str); User user2; user2.from_json(j2);
更简洁的方式:特化adl_serializer
可通过特化nlohmann::adl_serializer让接口更自然:
namespace nlohmann {
template<>
struct adl_serializer {
static void to_json(json& j, const User& u) {
j = json{{"name", u.name}, {"age", u.age}, {"email", u.email}};
}
static void from_json(const json& j, User& u) {
u.name = j.at("name").get();
u.age = j.at("age").get();
u.email = j.at("email").get();
}
};
}
之后即可直接使用:
json j = user; // 自动调用to_json User user2 = j.get基本上就这些。只要定义好转换规则,就能方便地在C++对象和JSON之间互转。注意处理字段缺失、类型错误等异常情况,提升健壮性。(); // 自动调用from_json











