C++最好用的 json库 nlohmann

C++最好用的 json库 nlohmann

1.安装

GitHub)使用非常简单,只需要引入json.hpp即可:

#include "json.hpp"
// 为方便起见,设置命名空间
using json = nlohmann::json;

对于 GCC 和 Clang 编译器来说,别忘了打开 C++11 支持,例如 -std=c++11

2.使用

2.1 创建json

// 创建一个空结构(null)
json j;
// 添加一个数值,存为 double
j["pi"] = 3.141;
// 添加一个布尔值,存为 bool
j["happy"] = true;
// 添加一个字符串,存为 std::string
j["name"] = "Niels";
// 添加另一个空对象,使用 nullptr
j["nothing"] = nullptr;
// 添加一个对象内的对象
j["answer"]["everything"] = 42;
// 添加一个数组,存为 std::vector (使用初始化器列表)
j["list"] = {1, 0, 2};
// 添加另一个对象 
j["object"] = {{"currency", "USD"}, {"value", 42.99}};
//相反,你也可以写(这看起来非常类似于上面的JSON)
json j2 = {
  {"pi", 3.141},
  {"happy", true},
  {"name", "Niels"},
  {"nothing", nullptr},
  {"answer", {
    {"everything", 42}
  }},
  {"list", {1, 0, 2}},
  {"object", {
    {"currency", "USD"},
    {"value", 42.99}
  }}
};

2.2 序列化和反序列化

//ps:注意,如果没有附加_json后缀,传递的字符串不解析,只是作为JSON字符串值。
//反序列化自字符串
//从字符串创建json对象
json j = "{ \"happy\": true, \"pi\": 3.141 }"_json;
//最好使用原始字面量创建json对象
auto j2 = R"(
  {
    "happy": true,
    "pi": 3.141
  }
)"_json;

上面的例子也可以显式地使用json::parse() 转成json

auto j3 = json::parse(R"({"happy": true, "pi": 3.141})");

你也可以一个JSON值的字符串表示(序列化)

//转换成字符串
std::string s = j.dump();    // {"happy":true,"pi":3.141}
//通过空间的缩进,序列化与漂亮的印刷
std::cout << j.dump(4) << std::endl;
// {
//     "happy": true,
//     "pi": 3.141
// }

2.3 任意类型的转换

任意类型都可以序列化至JSON

namespace ns {
    // a simple struct to model a person
    struct person {
        std::string name;
        std::string address;
        int age;
    };
}

ns::person p = {"Ned Flanders", "744 Evergreen Terrace", 60};

将每个值复制到JSON对象

json j;
j["name"] = p.name;
j["address"] = p.address;
j["age"] = p.age;

从JSON对象拷贝每个值

ns::person p {
    j["name"].get<std::string>(),
    j["address"].get<std::string>(),
    j["age"].get<int>()
};

上面这些这些赋值操作太繁琐了,幸运的是有更好的办法

// 创建 person 结构体
ns::person p {"Ned Flanders", "744 Evergreen Terrace", 60};

// person 结构体 转json
json j = p;

std::cout << j << std::endl;
// {"address":"744 Evergreen Terrace","age":60,"name":"Ned Flanders"}

// json 转person 结构体
auto p2 = j.get<ns::person>();

// that's it
assert(p == p2);

要使用以上方法,需要提供2个函数

using json = nlohmann::json;

namespace ns {
    void to_json(json& j, const person& p) {
        j = json{{"name", p.name}, {"address", p.address}, {"age", p.age}};
    }

    void from_json(const json& j, person& p) {
        j.at("name").get_to(p.name);
        j.at("address").get_to(p.address);
        j.at("age").get_to(p.age);
    }
} // namespace ns

就这样,当使用你的类型调用json构造函数时,你的自定义to_json方法将被自动调用。同样的, 当调用 get<your_type>() 或者 get_to(your_type&)from_json 方法将被调用

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱写代码的马良

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值