Json解析其实本身是一件很简单的事情,但是本次在工作中刚好遇到了一些相关问题,所以找个时间记录一下。
首先数据是放入Map集合然后使用Volley传输,本地缓存的时候使用了ORM数据库,因此不可避免的遇到需要将实体对象转为Map集合,或者Map集合转为实体对象的问题。
因为项目中本身使用了fastjson,所以这两步转换其实很简单,fastjson自身并没有提供直接的转换方案,所以必须要中间过渡一下:
比如实体对象转换为Map:
然后Map再转换为实体对象:
本身没有什么问题,但是真正引入项目中后,QA反馈项目会很卡,于是进行了分析(虽然后面发现跟这个暂时关系不大)。
首先针对Bean转换为map进行了修改,之前fastJson是需要先将Bean转换为String,再转换为Map,现在改成直接使用反射,来获取Bean对象中的每一个属性,以及对应的get和set方法。
效果确实不太一样了。
但是其实本身项目中有十几个Bean,然后每一个都有几十个属性,而且触发上报的频率其实相当高,所以其实本身不太想用反射。
如果直接在每一个Bean对象中做序列化转换呢?在每一个Bean中添加toMap(Object object)和toBean(Map map)的方法,再试一下效果呢?
效果很明显,原生直接转换的速度会比反射高一个数量级,然后直接反射比fastJson高1-3倍。
但是呢,直接手动去掉反射,代价太大了,每个Bean都有几十个属性,过于复杂。
参考美团对MSON的讲解,可以想起来完全将这一步工作自动化起来,那就使用AnnotationProcessor好了,编译前对Bean进行处理,添加对应的两个方法,减少人工处理的操作。
那么首先去AnnotationProcessor去看了一下,本来想自己编译出jar包,但是感觉很麻烦,那就直接去MVN仓库下载好了,这里只需要去下载androidannotations-4.4.0.jar和androidannotations-api-4.4.0.jar,地址:Group: AndroidAnnotations
按照下面的方式把两个jar包放进去:
然后就是开始配置,但是其实发现eclipse中的Java Compiler里面并没有Annotation Processing,此时就需要安装插件了,但是这里走了一个弯路,我自己的eclipse在安装插件时候总是出现问题,所以直接去了eclipse官网查看并按照流程安装:
Installing the Java Development Tools
至于如何配置compile-lib就比较简单了,我是参照这篇文章操作的,比较简单: