Convert是个重复造轮子的组件,却是个飞速的轮子。Redkale之所以重复造轮子主要追求性能和需要与网络数据的序列化很好的结合(Convert与ByteBuffer的结合)。 Convert在API设计思路上也与其他同类型的框架不一样,配置与序列化方法是分开的,大部分场景下配置项是固定的,因此不同的配置会动态生成对应的处理类以保证性能。
从包结构可以看出,Convert分三层:序列化与反序列化的抽象基础包;JSON包、BSON包。即使boolean、int、String这种基础数据类型都不是包含在Convert基础包中。以下是详细的结构图:
从上图可以看出,JSON与BSON是Convert基础包的实现,主要是实现Reader与Writer类。若需要实现XML格式的序列化,可以以JSON为参考自己编写。对于不是内置(ext子包下的数据类型)的且没有自定义处理(Encoder、Decoder)的数据类型, Convert会动态生成ObjectEncoder、ObjectDecoder对象。
Convert 的性能
一切不谈性能的框架都是在耍流氓!下面以JSON为例,与其他主流的JSON框架做个简单的性能比较(测试环境: DELL的普通笔记本),fastjson一直号称是Java性能最好的JSON解析框架,其使用Benchmark是 https://github.com/eishay/jvm-serializers/wiki,Redkale根据该数据编写了MediaContent类。实例由MediaContent.createDefault()方法所得。
由上图第一份报告看出,以MediaContent对象进行比较,fastjson的反序列化性能是最好的,gson性能最差。redkale、fastjson、jackson在序列化方面差距不大。第二份报告的测试对象是将第一份的MediaContent对象中所有的数值改成负数进行测试的,可以看出fastjson对于负数的处理性能很差,只是比gson稍强。第三份报告的测试对象是ConvertRecord对象,该对象的特点是包含int[]、long[]、List、Map数据。从结果可以看出fastjson的反序列化性能最差。redkale与jackson一直保持高性能。
综合起来看,Redkale的Convert性能是最好的。数据相差50毫秒以下的差距基本可以忽略,因为每次测试的结果会上下波动几十毫秒。
相关推荐
红帽集成Xen虚拟化化技术详解PPT-PowerPoin.pptx
《uC-GUI图形界面开发工具详解》 uC-GUI是一个高度优化、轻量级的图形用户界面库,专为嵌入式系统设计。这个压缩包包含的三个关键工具——uC-GUI-View、uC-GUI-BitmapConvert和uC-GUI-FontConvert-Demo,是uC-GUI...
嵌入式Linux系统开发技术详解--基于ARM(完整版) 嵌入式开发资料 更多资源,请登录我的博客:http://blog.csdn.net/hi_Emily 如需real 6410 嵌入式ARM11开发板请登录My_Shop:http://shop62249124.taobao.com/
《TeeChart应用技术详解》是由屈景辉编著的一本深入探讨TeeChart图形库的应用书籍,书中详细阐述了如何利用TeeChart在不同场景下进行数据可视化和图表制作。TeeChart是一款强大的图形组件库,适用于多种编程语言,如...
Tomcat与java web 开发技术详解-孙卫琴-第二版 这是271-540 Tomcat与java web 开发技术详解-孙卫琴-第二版 内容详细,清晰, javaweb必备
**echarts-convert脚本详解** `echarts-convert`是一个专门为ECharts图表库设计的脚本工具,它主要用于帮助开发者将ECharts的配置项转换为更易读、易维护的代码结构。ECharts是一款由百度开发的开源JavaScript图表...
Oracle RAC核心技术详解-高清-完整目录-2015年10月。。
《Tomcat与Java Web开发技术详解》是孙卫琴老师撰写的一本深入解析Java Web开发和Tomcat服务器的著作,其第二版进一步更新了内容,提供了更为详尽的指导。这本书针对初学者和有一定经验的开发者,旨在帮助读者掌握...
Web开发最好的自学教材 《Tomcat+java+web+开发技术详解》-孙卫琴-第2版 高清OCR 可标注 part1/3 ,要三个部分一起下载才能解压
序列化和反序列化我们可能经常会听到,其实通俗一点的解释,序列化就是把一个对象保存到一个文件或数据库字段中去,反序列化就是在适当的时候把这个文件再转化成原来的对象使用。序列化和反序列化最主要的作用有:1...
Nginx是一款高性能的Web服务器,它以其反向代理、负载均衡、静态文件处理和高效非...通过阅读《Nginx高性能Web服务器详解(完整版)》PDF文档,你将全面了解Nginx的各项特性和配置技巧,进一步提升你的运维和开发能力。
《5G物联网及NB-IoT技术详解》这本书籍详细阐述了5G和NB-IoT(窄带物联网)这两种关键技术在物联网领域的应用与发展趋势。5G作为第五代移动通信技术,不仅带来了更快的网络速度,更短的延迟,还为大规模物联网连接...
### 序列化与反序列化详解 #### 一、概念理解 序列化与反序列化是编程领域中非常重要的技术之一,它们主要用于将对象的状态转换为可以存储或传输的形式,以便于对象状态的持久化或者跨进程传输。具体而言: - **...
FEKO 5.4 电磁场分析技术与实例详解-2009
《PullToRefresh使用详解--构建下拉刷新的listView》博文对应原源码,博客地址:http://blog.csdn.net/harvic880925/article/details/17680305,讲解了PullToRefresh构建可下拉刷新的listView的过程;
04-Spring之初始化前、初始化、初始化后详解 05-Spring之AOP底层实现原理详解 06-Spring之事务及传播机制底层原理详解 07-Spring之@Configuration底层原理详解 08-手写模拟SpringBoot底层源码 09-SpringBoot自动配置...
ZooKeeper-分布式过程协同技术详解 ZooKeeper-分布式过程协同技术详解 ZooKeeper-分布式过程协同技术详解 ZooKeeper-分布式过程协同技术详解 ZooKeeper-分布式过程协同技术详解
### Java序列化与反序列化详解 #### 一、Java序列化概述 Java序列化(Serialization)是一项重要的功能,它可以将对象的状态转化为一系列字节,从而实现对象的持久化存储或在网络上传输。序列化机制使得Java对象...
精通SQL-结构化语言查询与详解精通SQL-结构化语言查询与详解精通SQL-结构化语言查询与详解精通SQL-结构化语言查询与详解精通SQL-结构化语言查询与详解精通SQL-结构化语言查询与详解精通SQL-结构化语言查询与详解精通...