本篇文章主要介绍了"两款JSON类库Jackson与JSON-lib的性能对比(新增第三款测试)",主要涉及到两款JSON类库Jackson与JSON-lib的性能对比(新增第三款测试)方面的内容,对于两款JSON类库Jackson与JSON-lib的性能对比(新增第三款测试)感兴趣的同学可以参考一下。

近日做一些性能优化工作,在挑选JSON类库时,发现除了一般常用的JSON-lib外,还有一款号称性能最快的JSON处理器Jackson,于是用上了刚学会的JMeter,对这两个类库进行了简单的性能对比。

Jackson:http://jackson.codehaus.org/

JSON-lib:http://json-lib.sourceforge.net/

Gson:http://code.google.com/p/google-gson/

测试环境:

1、工作电脑:Intel双核E8400 共6GHz,内存4GB,WinXP

2、JSON-lib用最新的JDK15,GSON版本是最新的v1.4,Jackson也是最新的v1.5.5,JDK-v1.6.0_20,JMeter-v2.4

3、测试时不开启任何无关进程,每完成一项测试后关闭JMeter整理内存后,再进行下一项测试,每项测试运行3次,取平均值

4、JSON转Java Bean意为将JSON格式转换成Java类,这个类内包括Map、List、Date、Integer/Long/Double、String等类型的属性,Java Bean转Json则同理。另外,两者互转,每次转换的数据都是随机生成

测试结果:

* 吞吐量的值越大越好,总耗时的值越小越好

JSON转Bean,5个线程并发,约200字节对象,1千万次转换:

  Jackson JSON-lib Gson
TPS 64113.7 8067.4 13952.8
总耗时(秒) 155 1238 700

Bean转JSON,5个线程并发,约200字节对象,1千万次转换:

  Jackson JSON-lib Gson
TPS 54802 15093.2 17308.2
总耗时(秒) 181 661 560

JSON转Bean,5个线程并发,约2K对象,1千万次转换:

  Jackson JSON-lib Gson
TPS 37314 2406.9 3657.50
总耗时(秒) 267 4120 2720

Bean转JSON,5个线程并发,约2K对象,1千万次转换:

  Jackson JSON-lib Gson
TPS 30922.2 4274.8 4977.00
总耗时(秒) 322 2320 2000

测试总结:

1、显而易见,无论是哪种形式的转换,Jackson > Gson > Json-lib。

Jackson的处理能力甚至高出Json-lib有10倍左右

2、JSON-lib似乎已经停止更新,最新的版本也是基于JDK15,而Jackson的社区则较为活跃;

3、在测试性能的同时,又以人肉方式对这三个类库转换的正确性 进行了检查 ,三者均达100%正确 

4、JSON-lib在转换诸如Date类型时较为累赘,如以下是两者的转换结果:

JSON-lib:

{"brithday":{"date":17,"day":2,"hours":9,"minutes":24,"month":7,"seconds":26,"time":1282008266398,"timezoneOffset":-480,"year":110}}

Jackson:

{"brithday":1282008123101}

5、JSON-lib依赖commons系列的包及 ezmorph包共 5个,而Jackson除自身的以外只依赖于commons-logging 
6、Jackson提供完整基于节点的Tree Model,以及完整的OJM数据绑定功能。

Jackson使用示例:

JacksonMapper:

创建为饿汉式单例模式 ,Jackson用于转换的核心类ObjectMapper无需每次都new一个object,官网上的一句话:can reuse, share globally

  1. /**
  2. * @author xuanyin
  3. *
  4. */
  5. public class JacksonMapper {
  6. /**
  7. *
  8. */
  9. private static final ObjectMapper mapper = new ObjectMapper();
  10. /**
  11. *
  12. */
  13. private JacksonMapper() {
  14. }
  15. /**
  16. *
  17. * @return
  18. */
  19. public static ObjectMapper getInstance() {
  20. return mapper;
  21. }
  22. }

JSON转Bean:

  1. ......
  2. String json = "...";
  3. ObjectMapper mapper = JacksonMapper.getInstance();
  4. YourBean bean = mapper.readValue(json, new YourBean().getClass());
  5. ......

Bean转JSON:

  1. ......
  2. YourBean bean = new YourBean();
  3. ......
  4. ObjectMapper mapper = JacksonMapper.getInstance();
  5. StringWriter sw = new StringWriter();
  6. JsonGenerator gen = new JsonFactory().createJsonGenerator(sw);
  7. mapper.writeValue(gen, bean);
  8. gen.close();
  9. String json = sw.toString();
  10. ......

* 上面两段代码中的YourBean当然也可以是Java的基本类型

近日做一些性能优化工作,在挑选JSON类库时,发现除了一般常用的JSON-lib外,还有一款号称性能最快的JSON处理器Jackson,于是用上了刚学会的JMeter,对这两个类库进行了简单的性能对比。

Jackson:http://jackson.codehaus.org/

JSON-lib:http://json-lib.sourceforge.net/

Gson:http://code.google.com/p/google-gson/

测试环境:

1、工作电脑:Intel双核E8400 共6GHz,内存4GB,WinXP

2、JSON-lib用最新的JDK15,GSON版本是最新的v1.4,Jackson也是最新的v1.5.5,JDK-v1.6.0_20,JMeter-v2.4

3、测试时不开启任何无关进程,每完成一项测试后关闭JMeter整理内存后,再进行下一项测试,每项测试运行3次,取平均值

4、JSON转Java Bean意为将JSON格式转换成Java类,这个类内包括Map、List、Date、Integer/Long/Double、String等类型的属性,Java Bean转Json则同理。另外,两者互转,每次转换的数据都是随机生成

测试结果:

* 吞吐量的值越大越好,总耗时的值越小越好

JSON转Bean,5个线程并发,约200字节对象,1千万次转换:

  Jackson JSON-lib Gson
TPS 64113.7 8067.4 13952.8
总耗时(秒) 155 1238 700

Bean转JSON,5个线程并发,约200字节对象,1千万次转换:

  Jackson JSON-lib Gson
TPS 54802 15093.2 17308.2
总耗时(秒) 181 661 560

JSON转Bean,5个线程并发,约2K对象,1千万次转换:

  Jackson JSON-lib Gson
TPS 37314 2406.9 3657.50
总耗时(秒) 267 4120 2720

Bean转JSON,5个线程并发,约2K对象,1千万次转换:

  Jackson JSON-lib Gson
TPS 30922.2 4274.8 4977.00
总耗时(秒) 322 2320 2000

测试总结:

1、显而易见,无论是哪种形式的转换,Jackson > Gson > Json-lib。

Jackson的处理能力甚至高出Json-lib有10倍左右

2、JSON-lib似乎已经停止更新,最新的版本也是基于JDK15,而Jackson的社区则较为活跃;

3、在测试性能的同时,又以人肉方式对这三个类库转换的正确性 进行了检查 ,三者均达100%正确 

4、JSON-lib在转换诸如Date类型时较为累赘,如以下是两者的转换结果:

JSON-lib:

{"brithday":{"date":17,"day":2,"hours":9,"minutes":24,"month":7,"seconds":26,"time":1282008266398,"timezoneOffset":-480,"year":110}}

Jackson:

{"brithday":1282008123101}

5、JSON-lib依赖commons系列的包及ezmorph包共5个,而Jackson除自身的以外只依赖于commons-logging
6、Jackson提供完整基于节点的Tree Model,以及完整的OJM数据绑定功能。

Jackson使用示例:

JacksonMapper:

创建为饿汉式单例模式 ,Jackson用于转换的核心类ObjectMapper无需每次都new一个object,官网上的一句话:can reuse, share globally

  1. /**
  2. * @author xuanyin
  3. *
  4. */
  5. public class JacksonMapper {
  6. /**
  7. *
  8. */
  9. private static final ObjectMapper mapper = new ObjectMapper();
  10. /**
  11. *
  12. */
  13. private JacksonMapper() {
  14. }
  15. /**
  16. *
  17. * @return
  18. */
  19. public static ObjectMapper getInstance() {
  20. return mapper;
  21. }
  22. }

JSON转Bean:

  1. ......
  2. String json = "...";
  3. ObjectMapper mapper = JacksonMapper.getInstance();
  4. YourBean bean = mapper.readValue(json, new YourBean().getClass());
  5. ......

Bean转JSON:

  1. ......
  2. YourBean bean = new YourBean();
  3. ......
  4. ObjectMapper mapper = JacksonMapper.getInstance();
  5. StringWriter sw = new StringWriter();
  6. JsonGenerator gen = new JsonFactory().createJsonGenerator(sw);
  7. mapper.writeValue(gen, bean);
  8. gen.close();
  9. String json = sw.toString();
  10. ......

* 上面两段代码中的YourBean当然也可以是Java的基本类型

文章不足之处欢迎大家留言指正:)

11 楼 wangym 2010-08-18   引用
wangliang_5290 写道
wangym 写道
wangliang_5290 写道
我碰到一个问题,要将字符串
String json = "{a:1, b:2}";
转化为 Map, 如果用Jackson的话,对字符串格式有严格要求,必须为
String json = "{\"a\":1, \"b\":2}";
否则报错,觉得不爽。

不知道是对Json了解不够呢, 还是Jackson就是这么要求的?

在JAVA里定义这样一个String自然是需要"\"给后面的引号进行转义,无论是用哪个JSON类库都一样,但在实际应用中,没有这个问题。

实际应用中json串不一定是在java中定义的,有可能是从页面传过来的,java只是负责解析。我以前用的是json-lib没有问题, 但是换成jackson后出现这个问题。不知道是不是对jackson的API研究不够?
1.json-lib 以下写法没有问题

  1. Map map = JSONObject.fromObject("{a:1, b:2}");

2.jackson 以下写法报异常

  1. Map map = new ObjectMapper().readValue("{a:1, b:2}", HashMap.class);

必须写成

  1. Map map = new ObjectMapper().readValue("{\"a\":1, \"b\":2}", HashMap.class);

不好意思一开始没明白你的意思
请开启支持字段名称不带引号的转换模式,默认是关闭的.
即将上面报异常的那句改成这样:

  1. Map map = new ObjectMapper().configure(Feature.ALLOW_UNQUOTED_FIELD_NAMES, true).readValue("{a:1, b:2}", HashMap.class);
24 楼 wangym 2011-01-18   引用
JSON转POJO时,若JSON中的某个字段在POJO中未定义,在默认情况下会抛异常转换失败,只要增加这个配置:
 
    1. Feature.FAIL_ON_UNKNOWN_PROPERTIES, false  
      就可以转换正常,即只转换定义的字段,未定义的字段忽略。

两款JSON类库Jackson与JSON-lib的性能对比(新增第三款测试)的更多相关文章

  1. 【Json】Jackson将json转换成泛型List

    Jackson将json转换成泛型List 获取泛型类型 /** * 获取泛型类型 * * @return */ protected Class<T> getGenericsType() ...

  2. JSON类库Jackson与JSON-lib性能对比[转]

    Jackson:http://jackson.codehaus.org/ JSON-lib:http://json-lib.sourceforge.net/ Gson:http://code.goog ...

  3. JSON类库Jackson优雅序列化Java枚举类

    1. 前言 在Java开发中我们为了避免过多的魔法值,使用枚举类来封装一些静态的状态代码.但是在将这些枚举的意思正确而全面的返回给前端却并不是那么顺利,我们通常会使用Jackson类库序列化对象为JS ...

  4. Atitit.json类库的设计与实现 ati json lib

    Atitit.json类库的设计与实现 ati json lib 1. 目前jsonlib库可能有问题,可能版本冲突,抛出ex1 2. 解决之道:1 2.1. 自定义json解析库,使用多个复合的js ...

  5. 我的Android进阶之旅------>解决Jackson、Gson解析Json数据时,Json数据中的Key为Java关键字时解析为null的问题

    1.问题描述 首先,需要解析的Json数据类似于下面的格式,但是包含了Java关键字abstract: { ret: 0, msg: "normal return.", news: ...

  6. Java下用Jackson进行JSON序列化和反序列化(转)

    Java下常见的Json类库有Gson.JSON-lib和Jackson等,Jackson相对来说比较高效,在项目中主要使用Jackson进行JSON和Java对象转换,下面给出一些Jackson的J ...

  7. json解析jackson ,Gson,等知识总结

    相关资料链接: Java构造和解析json数据的两种方法详解 java解析json Android网络之数据分析---使用Google Gson 解析Json数据 使用jackson在java中处理j ...

  8. Java下利用Jackson进行JSON解析和序列化

    Java下利用Jackson进行JSON解析和序列化   Java下常见的Json类库有Gson.JSON-lib和Jackson等,Jackson相对来说比较高效,在项目中主要使用Jackson进行 ...

  9. 开源 , KoobooJson一款高性能且轻量的JSON框架

    KoobooJson - 更小更快的C# JSON序列化工具(基于表达式树构建) 在C#领域,有很多成熟的开源JSON框架,其中最著名且使用最多的是 Newtonsoft.Json ,然而因为版本迭代 ...

随机推荐

  1. 第十三章 hadoop机架感知

    背景 分布式的集群通常包含非常多的机器,由于受到机架槽位和交换机网口的限制,通常大型的分布式集群都会跨好几个机架,由多个机架上的机器共同组成一个分布式集群.机架内的机器之间的网络速度通常都会高于跨机架 ...

  2. OpenCV for Python常用命令

      读取图像首先要导入OpenCV包 import cv2 OpenCV目前支持读取bmp.jpg.png.tiff等常用格式. //读取图片 img2 = cv2.imread('out-0022. ...

  3. 【UVa】1606 Amphiphilic Carbon Molecules(计算几何)

    题目 题目 分析 跟着lrj学的,理解了,然而不是很熟,还是发上来供以后复习 代码 #include <bits/stdc++.h> using namespace std; ; stru ...

  4. 【转】BMR(Block Media Recovery)

    关于RMAN的块恢复.Block是oracle数据库最小恢复单位.鉴于此,BMR可以大大缩短恢复的时间,另外,在进行BMR时不需要停掉数据库,可以直接在数据库open状态对数据文件进行恢复,只是需要恢 ...

  5. 压测工具Locuse的使用

    我是听朋友提起的"蝗虫"(Locust),然而她不想用python,我就拿来试一试~ http的 各种压测工具也已经太多了,所以主要是试试locust在当前比较流行的rpc协议上的 ...

  6. leetcode413

    public class Solution { public int NumberOfArithmeticSlices(int[] A) { , sum = ; ; i < A.Length; ...

  7. Unity 输入与控制

    1. 鼠标输入 有关的方法和变量如下: 在 Unity 中,鼠标位置用屏幕的像素坐标表示,屏幕左下角为(0,0),右上角为(Screen.width,Screen.height). 2. 键盘操作 有 ...

  8. Spring Boot @ControllerAdvice+@ExceptionHandler处理controller异常

    需求: 1.spring boot 项目restful 风格统一放回json 2.不在controller写try catch代码块简洁controller层 3.对异常做统一处理,同时处理@Vali ...

  9. 转载--js对象无法当成参数传递

    今天我碰到了这个问题一头雾水,明明记得对象是可以传参的啊.我使用了一款基于bootstrap的表格插件DataTables,想把行信息直接传给操作函数,方便编辑(此行信息是一个对象,按道理可以的啊), ...

  10. 运行django项目出现Invalid HTTP_HOST header: '192.168.1.111:8000'. You may need to add '192.168.1.111' to ALLOWED_HOSTS

    Request Method: GET Request URL: http://202.201.38.70:8000/angular Django Version: 1.11.3 Exception ...