当前位置: 首页 > news >正文

JSON介绍及使用

1.JSON

1.JSON简介

JSON(JavaScript Object Notation)是一种轻量级的数据序列化协议,基于文本,完全独立于语言。

JSON由键值对组成,支持以下几种数据类型:

  • 字符串:用双引号括起来的文本。

  • 数字:整数或浮点数。

  • 布尔值truefalse

  • 数组:用方括号[]括起来的有序数据集合,数组中的元素可以是任何类型。

  • 对象:用花括号{}括起来的无序键值对集合。

  • null:表示空值。

2.JSON for Modern C++

JSON for Modern C++(通常称为 nlohmann/json)是一个非常流行的现代 C++ JSON 库,它以简洁、易用和符合现代 C++ 编程风格而闻名。以下是它的简单介绍:

  • 单头文件库:整个库由一个头文件 json.hpp 组成,无需复杂的安装过程。
  • 类型安全:所有操作都经过严格的类型检查,避免了常见的错误。

  • 与 STL 容器无缝集成:可以直接与 std::vectorstd::map 等标准库容器进行转换。

  • 丰富的功能:支持 JSON 指针、JSON 补丁、自动类型推导等高级特性。

  • 易于使用:API 设计简洁直观,适合快速开发。

3.json.hpp使用 

1. 序列化(C++ 对象到 JSON 字符串)

#include <iostream>
#include <nlohmann/json.hpp>

using json = nlohmann::json;

int main() {
    // 创建一个 C++ 对象
    json j = {
        {"name", "Alice"},
        {"age", 25},
        {"city", "New York"}
    };

    // 序列化为 JSON 字符串
    std::string json_str = j.dump();

    // 输出 JSON 字符串
    std::cout << "Serialized JSON: " << json_str << std::endl;

    return 0;
}

2. 反序列化(JSON 字符串到 C++ 对象)

#include <iostream>
#include <nlohmann/json.hpp>

using json = nlohmann::json;

int main() {
    // JSON 字符串
    std::string json_str = R"({"name": "Alice", "age": 25, "city": "New York"})";

    // 反序列化为 C++ 对象
    json j = json::parse(json_str);

    // 访问解析后的数据
    std::cout << "Name: " << j["name"] << std::endl;
    std::cout << "Age: " << j["age"] << std::endl;
    std::cout << "City: " << j["city"] << std::endl;

    return 0;
}

3.get

get() 方法用于将 JSON 值转换为指定的类型。其基本语法如下:

Type value = json_object["key"].get<Type>();
Type value = json_object.get<Type>("key");
http://www.dtcms.com/a/113411.html

相关文章:

  • MathType安装
  • 写.NET可以指定运行SUB MAIN吗?调用任意一个里面的类时,如何先执行某段初始化代码?
  • vs环境中编译osg以及osgQt
  • RAGFlow:基于OCR和文档解析的下一代 RAG 引擎
  • [ctfshow web入门] web6
  • 解决cline等免费使用deepseek模型的问题
  • Lombok使用指南
  • SEO长尾词优化实战技巧
  • 2025大唐杯仿真2——基站开通
  • STM32提高篇: CAN通讯
  • 【Docker】在Orin Nano上使用Docker
  • SQL ServerAlways On 可用性组配置失败
  • [ctfshow web入门] web3
  • vue2项目中,多个固定的请求域名 和 通过url动态获取到的ip域名 封装 axios
  • [leetcode]1786. 从第一个节点出发到最后一个节点的受限路径数(Dijkstra+记忆化搜索/dp)
  • 私有部署stable-diffusion-webui
  • 44. 评论日记
  • STP学习
  • 【LeetCode】大厂面试算法真题回忆(48)--静态扫描最优成本
  • 为 IDEA 设置管理员权限
  • MYSQL 存储引擎 和 日志
  • 论文阅读笔记:Denoising Diffusion Implicit Models (5)
  • 英伟达Blackwell架构深度拆解:新一代GPU如何突破算力瓶颈?
  • DHCP Snooping 主要作用
  • 【Redis】通用命令
  • 聊聊Spring AI的ChromaVectorStore
  • #SVA语法滴水穿石# (007)关于 $past 的用法
  • P10587 「ALFR Round 2」C 小 Y 的数 Solution
  • Python 如何高效实现 PDF 内容差异对比
  • 房地产之后:探寻可持续扩张的产业与 GDP 新思