使用nlohmann json库进行序列化与反序列化

  • nlohmann源码仓库:https://github.com/nlohmann/json
  • 使用方式:将其nlohmann文件夹加入,包含其头文件json.hpp即可
  • demo
#include <iostream>
#include "nlohmann/json.hpp"
#include <vector>using json = nlohmann::json;// 定义嵌套的结构体
struct Address
{std::string street;std::string city;
};// 定义包含多种数据类型和结构体数组的主结构体
struct Person
{std::string name;int age;bool isStudent;std::vector<int> grades;Address address;std::vector<Address> addresses;
};int main()
{// 创建一个Person结构体实例Person person;person.name = "John";person.age = 30;person.isStudent = false;person.grades = {90, 85, 92};person.address = {"123 Main St", "Anytown"};person.addresses = {{"456 Elm St", "Somewhere"}, {"789 Oak St", "Nowhere"}};// 序列化结构体到JSONjson jsonData = {{"name", person.name},{"age", person.age},{"isStudent", person.isStudent},{"grades", person.grades},{"address", {{"street", person.address.street}, {"city", person.address.city}}},{"addresses", json::array()}};jsonData["age"] = 20;for (const auto &addr : person.addresses){jsonData["addresses"].push_back({{"street", addr.street},{"city", addr.city}});}// 将JSON对象转换为字符串std::string jsonString = jsonData.dump(4); // 4-space indentation for pretty formatting// 打印生成的JSON字符串std::cout << "Generated JSON:" << std::endl;std::cout << jsonString << std::endl;// 反序列化JSON字符串到结构体Person parsedPerson;json parsedData = json::parse(jsonString);parsedPerson.name = parsedData["name"];parsedPerson.age = parsedData["age"];parsedPerson.isStudent = parsedData["isStudent"];std::vector<int> parsedGrades = parsedData["grades"].get<std::vector<int>>();parsedPerson.address.street = parsedData["address"]["street"];parsedPerson.address.city = parsedData["address"]["city"];parsedPerson.addresses.clear();for (const auto &addr : parsedData["addresses"]){Address parsedAddr;parsedAddr.street = addr["street"];parsedAddr.city = addr["city"];parsedPerson.addresses.push_back(parsedAddr);}// 打印反序列化后的结构体成员std::cout << "Name: " << parsedPerson.name << std::endl;std::cout << "Age: " << parsedPerson.age << std::endl;std::cout << "Is Student: " << parsedPerson.isStudent << std::endl;std::cout << "Grades: ";for (int grade : parsedPerson.grades){std::cout << grade << " ";}std::cout << std::endl;std::cout << "Address: Street: " << parsedPerson.address.street << ", City: " << parsedPerson.address.city << std::endl;std::cout << "Addresses:" << std::endl;for (const auto &addr : parsedPerson.addresses){std::cout << "Street: " << addr.street << ", City: " << addr.city << std::endl;}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/64476.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Axure高保真原型】多图表动态切换

今天和大家分享多图表动态切换的原型模板&#xff0c;点击不同的图标可以动态切换对应的表&#xff0c;包括柱状图、条形图、饼图、环形图、折线图、曲线图、面积图、阶梯图、雷达图&#xff1b;而且图表数据可以在左侧表格中动态维护&#xff0c;包括增加修改和删除&#xff0…

v-limit-input + 正则限制特殊字符

src/directives/limitInput.js 设置自定义指令 limitInput 的逻辑 export default {// bind钩子 当 v-XXX 指令绑定到节点上时 触发bind (el) {el.oninput () > {console.log(1, el)let pattern new RegExp("[~!#$^&*()|{}:;,\\[\\].<>/?~&#xff01;#&…

设置TOMCAT SESSIONID 字符长度和生成算法

修改TOMCAT 默认的生成SESSION ID的算法和字符长度非常简单,只需修改context.xml中的<Manager>标签值,比如&#xff1a; <Manager sessionIdLength"20" pathname"SESSIONS.ser" maxActiveSessions"8000" secureRandomAlgorith…

TiDB同城双中心监控组件高可用方案

作者&#xff1a; Prest13 原文来源&#xff1a; https://tidb.net/blog/44b9b8b1 背景 在双中心部署tidb dr-auto sync集群&#xff0c;出于监控的高可用考虑&#xff0c;在物理分离的两个数据中心分别部署独立的prometheusalertmanagergrafana&#xff0c;实现任一监控均…

基于单片机的点阵电子显示屏上下左右移加减速系统

一、系统方案 本设计的任务就是完成一个1616的点阵设计&#xff0c;并能滚动显示“********************”内容。 主要内容是&#xff0c;能同时流动显示汉字&#xff1b;能实现显示汉字无闪烁&#xff1b;能实屏幕亮度较高。本LED显示屏能够以动态扫描的方式显示一个1616点阵汉…

前端Vue仿企查查 天眼查知识产权标准信息列表组件

引入Vue仿企查查天眼查知识产权标准信息列表组件 随着技术的不断发展&#xff0c;传统的开发方式使得系统的复杂度越来越高。在传统开发过程中&#xff0c;一个小小的改动或者一个小功能的增加可能会导致整体逻辑的修改&#xff0c;造成牵一发而动全身的情况。为了解决这个问题…

计网基础面试题

浏览器输入网址之后发生什么 1&#xff0c;DNS解析过程 2&#xff0c;三次握手 3&#xff0c;TLS通信 4&#xff0c;发送数据 5&#xff0c;四次挥手 TCP三次握手和四次挥手 两台计算机通信的过程 局域网通信———交换机——MAC地址 广域网通信———路由器——IP地址 网…

flutter plugins插件【二】【FlutterAssetsGenerator】

2、FlutterAssetsGenerator 介绍地址&#xff1a;https://juejin.cn/post/6898542896274735117 配置assets目录 ​ 插件会从pubspec.yaml文件下读取assets目录&#xff0c;因此要使用本插件&#xff0c;你需要在pubspec.yaml下配置资源目录 flutter:# The following line ens…

YOLOV8模型使用-检测-物体追踪

这个最新的物体检测模型&#xff0c;很厉害的样子&#xff0c;还有物体追踪的功能。 有官方的Python代码&#xff0c;直接上手试试就好&#xff0c;至于理论&#xff0c;有想研究在看论文了╮(╯_╰)╭ 简单介绍 YOLOv8 中可用的模型 YOLOv8 模型的每个类别中有五个模型用于检…

Bert和LSTM:情绪分类中的表现

一、说明 这篇文章的目的是评估和比较 2 种深度学习算法&#xff08;BERT 和 LSTM&#xff09;在情感分析中进行二元分类的性能。评估将侧重于两个关键指标&#xff1a;准确性&#xff08;衡量整体分类性能&#xff09;和训练时间&#xff08;评估每种算法的效率&#xff09;。…

Mac不想用iTerm2了怎么办

这东西真是让人又爱又恨&#xff0c;爱的是它的UI还真不错&#xff0c;恨的是它把我的环境给破坏啦&#xff01;让我每次启动终端之后都要重新source激活我的python环境&#xff0c;而且虚拟环境前面没有括号啦&#xff01;这怎么能忍&#xff01;在UI和实用性面前我断然选择实…

React笔记(三)类组件(1)

一、组件的概念 使用组件方式进行编程&#xff0c;可以提高开发效率&#xff0c;提高组件的复用性、提高代码的可维护性和可扩展性 React定义组件的方式有两种 类组件&#xff1a;React16.8版本之前几乎React使用都是类组件 函数组件:React16.8之后&#xff0c;函数式组件使…

ebay测评,物理环境与IP环境:解决平台风控问题的关键

近期eBay平台出现了大量风控问题&#xff0c;导致许多买家账号受到影响。实际上&#xff0c;这主要是由于环境搭建方面存在主要问题。时至2023年&#xff0c;许多人的技术方案仍停留在几年前&#xff0c;要么使用一键新机工具配合国外IP&#xff0c;要么使用指纹浏览器配合国外…

C语言暑假刷题冲刺篇——day6

目录 一、选择题 二、编程题 &#x1f388;个人主页&#xff1a;库库的里昂&#x1f390;CSDN新晋作者&#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏✨收录专栏&#xff1a;C语言每日一练✨相关专栏&#xff1a;代码小游戏、C语言初阶、C语言进阶&#x1f91d;希望作者的…

Kotlin inline、noinline、crossinline 深入解析

主要内容&#xff1a; inline 高价函数的原理分析Non-local returns noinlinecrossinline inline 如果有C语言基础的&#xff0c;inline 修饰一个函数表示该函数是一个内联函数。编译时&#xff0c;编译器会将内联函数的函数体拷贝到调用的地方。我们先看下在一个普通的 kot…

shell脚本学习-1

文章目录 一、定义变量二、使用变量三、将命令的结果赋值给变量四、变量操作 在 Bash shell 中&#xff0c;每一个变量的值都是字符串&#xff0c;无论你给变量赋值时有没有使用引号&#xff0c;值都会以字符串的形式存储。 这意味着&#xff0c;Bash shell 在默认情况下不会区…

mac idea启动没反应 无法启动

遇到的问题如下&#xff1a; 启动idea&#xff0c;没反应 无法启动&#xff0c;不论破解还是别的原因&#xff0c;总之无法启动了 应用程序–找到idea–右击显示包内容–Contents–MacOS–打开idea 弹出框提示如下&#xff1a; 双击这个idea可执行文件 1&#xff09;先查看日志…

Mac安装brew、mysql、redis

mac安装brew mac安装brewmac安装mysql并配置开机启动mac安装redis并配置开机启动 mac安装brew 第一步&#xff1a;执行. /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"第二步&#xff1a;输入开机密码 第三…

ElementUI浅尝辄止14:Carousel 走马灯

在有限空间内&#xff0c;循环播放同一类型的图片、文字等内容 1.如何使用&#xff1f; 结合使用el-carousel和el-carousel-item标签就得到了一个走马灯。幻灯片的内容是任意的&#xff0c;需要放在el-carousel-item标签中。默认情况下&#xff0c;在鼠标 hover 时底部的指示器…

正规黄金代理的三大要素

对于现货黄金投资来说&#xff0c;寻找一个正规的黄金代理是十分重要的问题。在目前的现货黄金投资市场中&#xff0c;现货黄金代理的数量很多&#xff0c;他们都致力于耕耘现货黄金投资市场。当越来越多的专业人士加入到现货黄金投资的市场中当中时&#xff0c;这个市场将会越…