fastjson源码解析——数组反序列化总结

2021SC@SDUSC

本文使用了mermaid流程图,本站暂未提供mermaid支持,请各位移步CSDN fastjson源码解析——数组反序列化总结

写在前面

继上一篇fastjson源码解析——对象反序列化总结总结了fastjson的parseObject()API的大致执行顺序,本文将使用相似的方法,将fastjson的parseArray()API的架构规整为流程图、类图等描述。在这之中,parseArray使用到parseObject的部分相同方法(比如对一段token的遍历,对象的构造等对单个对象的处理),在这里不再赘叙。
本文开始综合整理parseArray的架构

正式开始

parseArray()的API有两个,一个是针对单一类型的JSON对象(parseArray(String, Class<?>)),另一个是给每一个JSON对象都规定了元素类型的parseArray(String, Type[])。虽然这是两个方法,它们的执行逻辑其实并没有很大的差距,只是在细微的地方存在差别,比如对token的处理位置,但是每个步骤进行的操作逻辑基本相同,本文不再将其分开,只是提取出共同点后稍加说明

执行顺序

1. parseArray的操作主线逻辑

数组反序列化的主线操作逻辑在两种API中并无区别,只在多级API嵌套的过程中保存了不同的类型数据:parseArray(String, Class<?>保存的是单个类型的配置信息,只向通用反序列化器中传递了1个类型配置‘parseArray(String,Type[])保存了一个类型数组Type[],使用DefaultJSONParser时传入了这个数组。
主要逻辑:

graph TD
A[parseArray API]--多级API嵌套-->B[包含了所有配置的API]-->C[构造通用的反序列化器]
C-->D[检查token合法性]
D-->E[使用通用反序列化器反序列化]-->F[根据配置调整对象属性值]-->G[返回List类型数组]

2. 构造通用的反序列化器

这一步的逻辑在不同API中并没有什么区别,只是保存了一些需要的数据,同时将token的读取位置移动到一个JSON对象或数组的开始

graph LR
A[保存lexer]-->D[将token位置移动到下一个有效对象开始]-->E[跳转到下一位token]-->F[返回]
B[保存输入JSON字符串]-->D
C[保存config配置]-->D

3. 检查token合法性

合法性检查本来很简单,只是为了检查传入的字符串是否存在不合法的JSON格式,但是其在两个API中出现了两个处理的位置
流程图:

graph LR
A[检查token是否为空]-->D{调用通用反序列化器}
B[检查token是否存在EOF]-->D
C[检查token是否都是空格]-->D
D--Class<?>-->E[在JSON.parseArray中直接操作]
D--Type数组-->F[在parser.parseArray中检查]

4. 调用DefaultJSONParser.parseArray()反序列化

两个API差别不大,更多是在细节维护程序的可读性、规范性
流程:

graph TD
A[parser.parseArray]--多层级调用-->B[包含field约束的parseArray]-->C[细化token检查]-->D[判断每个field的类型]
D-->E[对每个field开始反序列化]
E-->F[调用类似parseObject的方法]-->G[保存到List]-->H[跳转到下一个对象的token]
H-->E
E--结束-->I[Object数组转化为List]-->J[返回List]

最后

到这里,我们JSON对象数组的反序列化的全部操作就已经完成了,我们获得了一个保存了所有对象的List数组。回顾这段历程,我们从最初的入口开始,不知不觉已经深入fastjson反序列化的底层实现,将其核心代码一一分析。我们不仅学到了开发者严密的逻辑,也看到了各种代码技巧。
本文使用合适的工具,将fastjson中parseArray()的两个API的调用逻辑、反序列化的操作顺序等简单明了地总结概述。到这里,fastjson反序列化源码分析就全部结束了,谢谢大家的关注!
对fastjson源码的解析,让我不仅仅学到了JSON字符串反序列化的操作逻辑,更让我清清楚楚地感受到阿里巴巴开发者的代码编写规范、命名规范,以及更重要的,对代码冗余精妙的把握,对高内聚、低耦合程序结构的设计等等,也让我积累了不少看代码分析代码的能力,在这里我也向fastjson开源开发团队致以我个人诚挚的敬意与谢意,没有开源社区的同行用爱发电,一次次贡献出自己的休息时间,我们也无法用到JSON解析benchmark霸榜的fastjson包,也无法看到专业开发者对代码的神级优化,谢谢!、
对fastjson反序列化源码解析的文章到此为止,谢谢大家的一路陪伴!
感谢各位老师的阅读与指导!

发表评论