博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
改进fastjson的WriteClassName特性时的输出数据容量
阅读量:6431 次
发布时间:2019-06-23

本文共 511 字,大约阅读时间需要 1 分钟。

  hot3.png

在使用fastjson输出省市县三级信息时,数量高达300K,由于我们的数据结构相同,因此每个类都输出了完整的类名称

因此,是否可以采用索引方式用简单的数字引用达到减轻很长类名称的作用呢?

因此,我们设计一种简单类名称扩展

    1."@type":"com.hd.doctor.mobile.api.DictionaryBean#1"表示一个完整的类名称并且带有一个1的索引号,表示该类名被索引化

    2. "@type":"#1" 则表示该类名称引用之前被索引化的类名称,从而找到类名称com.hd.doctor.mobile.api.DictionaryBean

 解决方案:

  1. SerilaizeFeature 中添加WriteClassNameRef特性,该特性仅仅在WriteClassName支持的情况下才有效

  2. 序列化时,判断是否支持WriteClassRef特性,是则判断该类名是否已经被索引,是则直接输出#{索引},否则输出类名+#{新索引}

    3.反序列化时,以相反的角度判断类名和处理

经过测试,数据从300k降低到了173k

转载于:https://my.oschina.net/aruan/blog/478200

你可能感兴趣的文章
16.Python网络爬虫之Scrapy框架(CrawlSpider)
查看>>
stm 常用头文件
查看>>
mac 删除文件夹里所有的.svn文件
查看>>
程序制作 代写程序 软件定制 代写Assignment 网络IT支持服务
查看>>
mysql 案例~select引起的性能问题
查看>>
直接读取图层
查看>>
springsecurity 源码解读 之 RememberMeAuthenticationFilter
查看>>
HTML5标准学习 - 编码
查看>>
JS 时间戳转星期几 AND js时间戳判断时间几天前
查看>>
UVa11426 最大公约数之和(正版)
查看>>
SQL练习之求解填字游戏
查看>>
UIApplication
查看>>
12:Web及MySQL服务异常监测案例
查看>>
数据库性能优化之冗余字段的作用
查看>>
DBA_实践指南系列9_Oracle Erp R12应用补丁AutoPatch/AutoControl/AutoConfig(案例)
查看>>
数据库设计三大范式
查看>>
ionic 字体的导入方法
查看>>
内部类详解
查看>>
类加载机制
查看>>
mongodb int型id 自增
查看>>