前言
在restful风格流行的今天,json想必大家都不陌生。JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。在Java中,有很多json库,比如阿里巴巴的fastjson,谷歌的gson等等。那么,它们之间的性能表现如何呢?下面就通过实际例子分析下。
原创声明
本文首发于头条号【Happyjava】https://www.toutiao.com/c/user/85644464579/ 欢迎转载,但须保留此段声明。
用于比较的库
用4中json库进行比较,分别是:FastJson,Gson,Jackson
比较方式
主要从开发中常用的几方面入手比较,分别如下:
1、Java对象转化成为json字符串
2、集合对象转化成为json字符串
3、字符串转化成json对象
4、字符串转化成java对象
5、字符串转化为json数组
6、字符串转化成为java集合
每种操作,通过计算重复执行100 0000次进行性能比较。
结果对比
从结果看,fastjson的速度是遥遥领先的,gson的速度最慢,这也是为什么被戏称为“龟son“的原因。
三个库的对比
jackson是SpringMVC默认的json转化库,有良好的稳定性的同时,也有不错的性能。
fastjson速度是最快的,但是版本迭代快,但是经常爆出存在漏洞,如果是比较保守的项目,如银行政府项目,是不推荐使用的。但是,fastjson的api设计,本人认为是所有json库里最优雅方便的。
gson是谷歌出品,但是速度上就比较慢。
Java对象
Person.java
- @Data
- public class Person {
- private Integer id;
- private String username;
- private Integer age;
- private String address;
- }
fastjson测试
使用的是fastjson1.2.58版本,也是目前最新的fastjson版本。
测试代码如下:
- public static void main(String[] args) {
- // 构造对象
- Person person = new Person();
- person.setId(99999);
- person.setUsername("Happyjava");
- person.setAddress("广东省广州市,上海市,北京市,广东省深圳市,浙江省杭州市,");
- person.setAge(100);
-
- // Java对象转化成为json字符串
- long start = System.currentTimeMillis();
- for (int i = 0; i < 1000000; i++) {
- String string = JSON.toJSONString(person);
- }
- System.out.println("Java对象转化成为json字符串耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 集合对象转化成为json字符串
- List<Person> list = new ArrayList<>();
- for (int i = 0; i < 100; i++) {
- list.add(person);
- }
- start = System.currentTimeMillis();
- for (int i = 0; i < 1000000; i++) {
- String string = JSON.toJSONString(list);
- }
- System.out.println("集合对象转化成为json字符串耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化成json对象
- start = System.currentTimeMillis();
- String jsonsString = JSON.toJSONString(person);
- for (int i = 0; i < 1000000; i++) {
- JSONObject jsonObject = JSON.parseObject(jsonsString);
- }
- System.out.println("字符串转化成json对象耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化成java对象
- start = System.currentTimeMillis();
- for (int i = 0; i < 1000000; i++) {
- Person person1 = JSON.parseObject(jsonsString, Person.class);
- }
- System.out.println("字符串转化成java对象耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化为json数组
- start = System.currentTimeMillis();
- String jsonArrayStr = JSON.toJSONString(list);
- for (int i = 0; i < 1000000; i++) {
- JSONArray objects = JSON.parseArray(jsonArrayStr);
- }
- System.out.println("字符串转化为json数组耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化成为java集合
- start = System.currentTimeMillis();
- for (int i = 0; i < 1000000; i++) {
- List<Person> list1 = JSON.parseArray(jsonArrayStr, Person.class);
- }
- System.out.println("字符串转化成为java集合耗时:" + (System.currentTimeMillis() - start) + "ms");
- }
结果如下:
- Java对象转化成为json字符串耗时:625ms
- 集合对象转化成为json字符串耗时:7161ms
- 字符串转化成json对象耗时:640ms
- 字符串转化成java对象耗时:296ms
- 字符串转化为json数组耗时:17437ms
- 字符串转化成为java集合耗时:28611ms
gson测试
使用的是2.8.5版本,同时也是目前的最新版本。
测试代码如下:
- private static Gson gson = new Gson();
-
- public static void main(String[] args) {
- // 构造对象
- Person person = new Person();
- person.setId(99999);
- person.setUsername("Happyjava");
- person.setAddress("广东省广州市,上海市,北京市,广东省深圳市,浙江省杭州市,");
- person.setAge(100);
-
- // Java对象转化成为json字符串
- long start = System.currentTimeMillis();
- for (int i = 0; i < 1000000; i++) {
- String string = gson.toJson(person);
- }
- System.out.println("Java对象转化成为json字符串耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 集合对象转化成为json字符串
- List<Person> list = new ArrayList<>();
- for (int i = 0; i < 100; i++) {
- list.add(person);
- }
- start = System.currentTimeMillis();
- for (int i = 0; i < 1000000; i++) {
- String string = gson.toJson(list);
- }
- System.out.println("集合对象转化成为json字符串耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化成json对象
- start = System.currentTimeMillis();
- String jsonsString = gson.toJson(person);
- for (int i = 0; i < 1000000; i++) {
- JsonObject jsonObject = gson.fromJson(jsonsString, JsonObject.class);
- }
- System.out.println("字符串转化成json对象耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化成java对象
- start = System.currentTimeMillis();
- for (int i = 0; i < 1000000; i++) {
- Person person1 = gson.fromJson(jsonsString, Person.class);
- }
- System.out.println("字符串转化成java对象耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化为json数组
- start = System.currentTimeMillis();
- String jsonArrayStr = gson.toJson(list);
- for (int i = 0; i < 1000000; i++) {
- JsonArray objects = gson.fromJson(jsonArrayStr, JsonArray.class);
- }
- System.out.println("字符串转化为json数组耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化成为java集合
- Type type = new TypeToken<List<Person>>() {
- }.getType();
- start = System.currentTimeMillis();
- for (int i = 0; i < 1000000; i++) {
- List<Person> list1 = gson.fromJson(jsonArrayStr, type);
- }
- System.out.println("字符串转化成为java集合耗时:" + (System.currentTimeMillis() - start) + "ms");
- }
-
- }
测试结果如下:
- Java对象转化成为json字符串耗时:1244ms
- 集合对象转化成为json字符串耗时:86041ms
- 字符串转化成json对象耗时:1009ms
- 字符串转化成java对象耗时:793ms
- 字符串转化为json数组耗时:62112ms
- 字符串转化成为java集合耗时:51087ms
Jackson测试
测试代码如下:
- public static void main(String[] args) throws Exception {
- ObjectMapper mapper = new ObjectMapper();
-
- // 构造对象
- Person person = new Person();
- person.setId(99999);
- person.setUsername("Happyjava");
- person.setAddress("广东省广州市,上海市,北京市,广东省深圳市,浙江省杭州市,");
- person.setAge(100);
-
- // Java对象转化成为json字符串
- long start = System.currentTimeMillis();
- for (int i = 0; i < 1000000; i++) {
- String string = mapper.writeValueAsString(person);
- }
- System.out.println("Java对象转化成为json字符串耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 集合对象转化成为json字符串
- List<Person> list = new ArrayList<>();
- for (int i = 0; i < 100; i++) {
- list.add(person);
- }
- start = System.currentTimeMillis();
- for (int i = 0; i < 1000000; i++) {
- String string = mapper.writeValueAsString(list);
- }
- System.out.println("集合对象转化成为json字符串耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化成json对象
- start = System.currentTimeMillis();
- String jsonsString = mapper.writeValueAsString(person);
- for (int i = 0; i < 1000000; i++) {
- ObjectNode objectNode = mapper.readValue(jsonsString, ObjectNode.class);
- }
- System.out.println("字符串转化成json对象耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化成java对象
- start = System.currentTimeMillis();
- for (int i = 0; i < 1000000; i++) {
- Person person1 = mapper.readValue(jsonsString, Person.class);
- }
- System.out.println("字符串转化成java对象耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化为json数组
- start = System.currentTimeMillis();
- String jsonArrayStr = mapper.writeValueAsString(list);
- for (int i = 0; i < 1000000; i++) {
- ArrayNode arrayNode = mapper.readValue(jsonArrayStr, ArrayNode.class);
- }
- System.out.println("字符串转化为json数组耗时:" + (System.currentTimeMillis() - start) + "ms");
-
- // 字符串转化成为java集合
- start = System.currentTimeMillis();
- JavaType javaType = mapper.getTypeFactory().constructParametricType(List.class, Person.class);
- for (int i = 0; i < 1000000; i++) {
- List<Person> list1 = mapper.readValue(jsonArrayStr, javaType);
- }
- System.out.println("字符串转化成为java集合耗时:" + (System.currentTimeMillis() - start) + "ms");
- }
-