整体架构
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