【Android】【框架】【JSON】【fastjson】

整体架构

fastjson和Gson的整体思路一致,实际上大多数语言解析库的思路都是差不多的,即抽象出一个写入写出的转换器,以及一个保存数据的容器
而fastjson的不同之处在于,做了大量的算法优化,使得其解析性能远超其他JSON解析库

SerializeWriter

Gson直接采用的是StringBuilder,fastjson基于JSON解析机制,定制了更适合JSON解析过程的JSON容器
此外用ThreadLocal保存上次序列化的结果,以便于下次序列化的适合使用

ASM

获取对象属性Gson是通过ReflectiveTypeAdapterFactory做的,反射遍历对象的field
为了优化这一点,fastjson使用ASM,在编译期给JavaBean注入getter、setter,免去了反射消耗
同时为了防止fastjson包体积过大,简化了ASM代码,仅保留需要的一部分

IdentityHashMap

HashMap扩容时会调用transfer方法,在多线程情况下,链表会循环引用,导致程序死循环
而ConcurrentHashMap性能不高,尽管做了很精细的并发处理,但是同时也损失了一部分性能
于是基于此,定制了安全的HashMap:IdentityHashMap

token预测

读取key后,后面字符最大可能性是冒号
读取value后,可能是逗号,也可能是花括号
基于此,设计了token预测算法

快速模式

快速模式假定key-value是有序的,读取的时候只需要做key的匹配,不用考虑value
若发现value不匹配,则退出快速模式,进入常规模式
通过这种方式,可以少读取50%以上的token

symbolTable

缓存经常使用的关键字,生成hash并保存,在遍历chars[]的时候优先使用缓存,避免创建新的字符串对象

后记

有什么写得错误、让人费解或遗漏的地方,希望可以不吝赐教,我会马上更改

学习自

https://www.iteye.com/blog/wenshao-1142031
https://www.iteye.com/topic/1098058

你可能感兴趣的:(【Android】【框架】【JSON】【fastjson】)