序列化与反序列化——FastJSON、Jackson、Gson性能测试

本文通过性能测试对比了FastJSON、Jackson和Gson在序列化和反序列化方面的表现。在小数据量场景下,Gson表现出色;而大数据量时,Jackson成为首选。由于FastJSON的安全问题,建议在性能和安全之间权衡。
摘要由CSDN通过智能技术生成

背景

起因是公司原先用的是阿里开源的FastJSON,大家用的也比较顺手,但是在出现了两次严重的漏洞后,公司决定放弃FastJSON,使用其他序列化/反序列化工具。考虑大家常用的无非就是FastJSON、Jackson和Gson这三种,因此领导让我调研一下到底是使用Gson还是Jackson。

关于漏洞这里我多说一句,建议大家还真得把这个事情当一个事情。我之前就被漏洞坑了一把,在一台linux服务器上部署了6.5版本的confluence,后来阿里云也发紧急通知了,告知赶紧升级,然而我并没有当一回事,过了没两天我就中招了,这台机器被挖矿了,什么都干不了,只能是初始化系统,好一顿折腾~

秉持着严谨且负责的精神,这个事情还是要好好做一下子的~

测试结果预告

 

 

前置准备工作

为了营造一个相对准确、互不影响的测试环境,我们需要有以下限制(要求):

  • 同一台机器,即我的mac:
MacBook Pro (16-inch, 2019) 
处理器 2.3 GHz 八核Intel Core i9 
内存16 GB 2667 MHz DDR4
硬盘 1T
  • JVM相关参数配置:
#JDK版本
jdk1.8.0_151
#运行参数
-Xms4g -Xmx4g -XX:+UseG1GC
  • 三种JSON引擎版本:
com.fasterxml.jackson.core.jackson:2.11.1
com.google.code.gson:2.8.6
com.alibaba.fastjson:1.2.72

序列化与反序列化

搞事情之前,我们先来复习一下什么是序列化与反序列化:

序列化:把Java对象转换为字节序列的过程。

反序列化:把字节序列恢复为Java对象的过程。

对象的序列化主要有两种用途:

持久化对象:把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;

网络传输对象:在网络上传送对象的字节序列。

代码测试

创建一个对象,包含Boolean、Integer、Long、Double、Date、String、ArrayList、HashMap等数据类型,构造方法即初始化好对象,方便后面使用:

package com.performance.json.bean;
import com.performance.jso
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值