2405C++,部分解析数格

2024-05-02 15:04
文章标签 c++ 解析 部分 数格 2405

本文主要是介绍2405C++,部分解析数格,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文

如果一个很大数格串,然后用户只想解析其中的一个字段,一般需要遍历所有串全部解析所有字段,这样效率就很低了.

如果可部分解析数格字段,就可避免全部解析了,从而获得更好的性能.

iguana已增加了支持部分解析数格特征,比如这样一个数格对象:

struct some_test_t {int id1;std::string name;
};
REFLECTION(some_test_t, id1, name);
struct dummy_nest_t {int id;some_test_t t;
};
REFLECTION(dummy_nest_t, id, t);

该对象序化成数格串后,我反序化时,我只想反序化dummy_nest_t::id该字段,其它的不需要解析.代码可这样写:

  dummy_nest_t t{42, {43, "tom"}};std::string str;iguana::to_json(t, str); //序化到`数格`{dummy_nest_t t1;iguana::from_json<&dummy_nest_t::id>(t1, str); //部分反序化到`dummy_nest_t::id`CHECK(t1.id == 42);}

from_json只会解析id对应的那段串,不会解析其它的串,所以t1中,只赋值id.

如果要部分解析嵌套对象some_test_t中的名字字段该怎么做呢?方法类似:

{some_test_t t1;iguana::from_json<&some_test_t::name, dummy_nest_t>(t1, str); //部分解析嵌套对象的`名字`字段CHECK(t1.name == "tom");
}

解析dummy_nest_t嵌套对象字段时,需要填充第二个参数,即根对象的类型,这里就是dummy_nest_t.

之所以嵌套对象需要填根对象的类型,是为了安全性,iguana部分解析是有约束条件的,条件就是不要有名字相同,否则,反序化时无法区分到底应该解析哪个.
填根对象类型时,iguana会在编译期检查所有字段,包括嵌套对象字段是否有重名,如果重名了就会给出一个编译期错误.

除此外,如果填一个不属于根对象的字段,iguana也会在编译期检查出来.

比如我部分解析时填了个不属于dummy_nest_t的字段:

some_test_t t1;iguana::from_json<&person::name, dummy_nest_t>(t1, str); //编译错误:成员不属于对象

如果存在重名字段对象呢?

struct some_test_t1 {int id;std::string name;
};
REFLECTION(some_test_t1, id, name);
struct dummy_nest_t1 {int id;some_test_t1 t;
};
REFLECTION(dummy_nest_t1, id, t);

dummy_nest_t1的字段id和嵌套对象some_test_t1的字段id,二者重名了,此时去部分解析:

dummy_nest_t1 t1;
iguana::from_json<&dummy_nest_t1::id>(t1, str); //编译错误:字段名重复

因此该部分解析非常安全的,因为它在编译期检查安全性.话说iguana无论是易用性还是各种很酷的特性都是很不错的,为啥star还这么少呢?
桃李不言,下自成蹊,相信总有一天大家会发现它是个多么好用的库.

这篇关于2405C++,部分解析数格的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/954517

相关文章

利用c++判断水仙花数并输出示例代码

《利用c++判断水仙花数并输出示例代码》水仙花数是指一个三位数,其各位数字的立方和恰好等于该数本身,:本文主要介绍利用c++判断水仙花数并输出的相关资料,文中通过代码介绍的非常详细,需要的朋友可以... 以下是使用C++实现的相同逻辑代码:#include <IOStream>#include <vec

基于C++的UDP网络通信系统设计与实现详解

《基于C++的UDP网络通信系统设计与实现详解》在网络编程领域,UDP作为一种无连接的传输层协议,以其高效、低延迟的特性在实时性要求高的应用场景中占据重要地位,下面我们就来看看如何从零开始构建一个完整... 目录前言一、UDP服务器UdpServer.hpp1.1 基本框架设计1.2 初始化函数Init详解

C++ 右值引用(rvalue references)与移动语义(move semantics)深度解析

《C++右值引用(rvaluereferences)与移动语义(movesemantics)深度解析》文章主要介绍了C++右值引用和移动语义的设计动机、基本概念、实现方式以及在实际编程中的应用,... 目录一、右值引用(rvalue references)与移动语义(move semantics)设计动机1

MySQL 筛选条件放 ON后 vs 放 WHERE 后的区别解析

《MySQL筛选条件放ON后vs放WHERE后的区别解析》文章解释了在MySQL中,将筛选条件放在ON和WHERE中的区别,文章通过几个场景说明了ON和WHERE的区别,并总结了ON用于关... 今天我们来讲讲数据库筛选条件放 ON 后和放 WHERE 后的区别。ON 决定如何 "连接" 表,WHERE

Mybatis的mapper文件中#和$的区别示例解析

《Mybatis的mapper文件中#和$的区别示例解析》MyBatis的mapper文件中,#{}和${}是两种参数占位符,核心差异在于参数解析方式、SQL注入风险、适用场景,以下从底层原理、使用场... 目录MyBATis 中 mapper 文件里 #{} 与 ${} 的核心区别一、核心区别对比表二、底

Agent开发核心技术解析以及现代Agent架构设计

《Agent开发核心技术解析以及现代Agent架构设计》在人工智能领域,Agent并非一个全新的概念,但在大模型时代,它被赋予了全新的生命力,简单来说,Agent是一个能够自主感知环境、理解任务、制定... 目录一、回归本源:到底什么是Agent?二、核心链路拆解:Agent的"大脑"与"四肢"1. 规划模

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

C++构造函数中explicit详解

《C++构造函数中explicit详解》explicit关键字用于修饰单参数构造函数或可以看作单参数的构造函数,阻止编译器进行隐式类型转换或拷贝初始化,本文就来介绍explicit的使用,感兴趣的可以... 目录1. 什么是explicit2. 隐式转换的问题3.explicit的使用示例基本用法多参数构造