2021SC@SDUSC
文章目录
写在前面
继上一篇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
时传入了这个数组。
主要逻辑:
2. 构造通用的反序列化器
这一步的逻辑在不同API中并没有什么区别,只是保存了一些需要的数据,同时将token
的读取位置移动到一个JSON对象或数组的开始
3. 检查token
合法性
合法性检查本来很简单,只是为了检查传入的字符串是否存在不合法的JSON格式,但是其在两个API中出现了两个处理的位置
流程图:
4. 调用DefaultJSONParser.parseArray()
反序列化
两个API差别不大,更多是在细节维护程序的可读性、规范性
流程:
最后
到这里,我们JSON对象数组的反序列化的全部操作就已经完成了,我们获得了一个保存了所有对象的List数组。回顾这段历程,我们从最初的入口开始,不知不觉已经深入fastjson反序列化的底层实现,将其核心代码一一分析。我们不仅学到了开发者严密的逻辑,也看到了各种代码技巧。
本文使用合适的工具,将fastjson中parseArray()的两个API的调用逻辑、反序列化的操作顺序等简单明了地总结概述。到这里,fastjson反序列化源码分析就全部结束了,谢谢大家的关注!
对fastjson源码的解析,让我不仅仅学到了JSON字符串反序列化的操作逻辑,更让我清清楚楚地感受到阿里巴巴开发者的代码编写规范、命名规范,以及更重要的,对代码冗余精妙的把握,对高内聚、低耦合程序结构的设计等等,也让我积累了不少看代码分析代码的能力,在这里我也向fastjson开源开发团队致以我个人诚挚的敬意与谢意,没有开源社区的同行用爱发电,一次次贡献出自己的休息时间,我们也无法用到JSON解析benchmark霸榜的fastjson包,也无法看到专业开发者对代码的神级优化,谢谢!、
对fastjson反序列化源码解析的文章到此为止,谢谢大家的一路陪伴!
感谢各位老师的阅读与指导!