手机版
你好,游客 登录 注册 搜索
背景:
阅读新闻

JSON for Modern C++发布3.1版本

[日期:2018-02-19] 来源:infoq.com  作者:Sergio De Simone ,译者 罗远航 [字体: ]

JSON for Modern C++ 3.1版本增加了对Universal Binary JSON(UBJSON)规范和JSON合并补丁(Merge Patch)的支持。

UBJSON是支持Modern C++几种格式之一,它可以减少编码值的大小,加快解码速度。除了UBJSON,CBORMessagePack也同样支持Modern C++。 每种格式都有不同的优势,选择哪种格式取决于你所需要的数据类型。在这三种格式中,UBJSON是唯一完整二进制格式的,这就意味着所有的JSON值都可以转换成UBJSON,并且所有的UBJSON值也都能转换成JSON。

JSON合并补丁格式的作用是声明两个JSON文档之间的差异。这种格式是与HTTP PATCH一起使用的,它能够对资源进行部分更新,而HTTP PUT则用于对资源进行完全替换。JSON合并补丁允许你只对JSON的一部分进行定义,并且将其合并到服务器端。这比使用基本的JSON补丁格式更加方便,基本的JSON补丁格式依赖于一组操作的规范来对原始的JSON文档进行修补。例如:

// a JSON value
json j_document = R"({
  "a": "b",
  "c": {
    "d": "e",
    "f": "g"
  }
})"_json;

// a JSON patch (RFC 6902)
json j_patch_1 = R"([
  { "op": "replace", "path": "/a", "value": "z" },
  { "op": "remove", "path": "/f"}
])"_json;

// a JSON Merge patch (RFC 7386)
json j_patch_2 = R"({
  "a":"z",
  "c": {
    "f": null
  }
})"_json;

JSON for Modern C++库旨在提供一种直观的语法来对JSON数据进行处理,就好像该JSON数据是头等(first-class)数据类型一样。例如,你能通过以下语句来对一个对象进行初始化:

json j2 = {
  {"pi", 3.141},
  {"happy", true},
  {"name", "Niels"},
  {"nothing", nullptr},
  {"answer", {
    {"everything", 42}
  }},
  {"list", {1, 0, 2}},
  {"object", {
    {"currency", "USD"},
    {"value", 42.99}
  }}
}

同样地,你可以通过将__json附加至json代码后边来对JSON代码进行解码:

auto j2 = R"(
  {
    "happy": true,
    "pi": 3.141
  }
)"_json;

JSON for Modern C++另外的优点是易于集成,这要归功于它可以被封装于一个单独的头文件json.hpp中,而不需要任何外部库或依赖项。除此之外,它还声称能够通过100%的代码覆盖单元测试,并且不存在内存泄漏。

查看英文原文:JSON for Modern C++ Reaches Version 3.1

本文永久更新链接地址https://www.linuxidc.com/Linux/2018-02/150999.htm

linux
相关资讯       json  JSON for Modern C++ 
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款