最后更新:2010-08-18,增加对GSON的性能测试
近日做一些性能优化工作,在挑选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
/**
* @author xuanyin
*
*/
public class JacksonMapper {
/**
*
*/
private static final ObjectMapper mapper = new ObjectMapper();
/**
*
*/
private JacksonMapper() {
}
/**
*
* @return
*/
public static ObjectMapper getInstance() {
return mapper;
}
}
JSON转Bean:
......
String json = "...";
ObjectMapper mapper = JacksonMapper.getInstance();
YourBean bean = mapper.readValue(json, new YourBean().getClass());
......
Bean转JSON:
......
YourBean bean = new YourBean();
......
ObjectMapper mapper = JacksonMapper.getInstance();
StringWriter sw = new StringWriter();
JsonGenerator gen = new JsonFactory().createJsonGenerator(sw);
mapper.writeValue(gen, bean);
gen.close();
String json = sw.toString();
......
* 上面两段代码中的YourBean当然也可以是Java的基本类型
文章不足之处欢迎大家留言指正:)
分享到:
相关推荐
3. `commons-lang-2.3.jar`:Apache Commons Lang是一个实用工具类库,包含了一些对Java内置类的扩展和增强,比如字符串处理、日期时间等,有助于在处理JSON数据时进行数据类型转换和格式化。 4. `json-lib-2.4-jdk...
Java下常见的Json类库有Gson、JSON-lib和Jackson等,Jackson相对来说比较高效,在项目中主要使用Jackson进行JSON和Java对象转换
Java下常见的Json类库有Gson、JSON-lib和Jackson等,Jackson相对来说比较高效,在项目中主要使用Jackson进行JSON和Java对象转换
本主题主要关注`json-lib`在Java中的应用及其依赖的类库。`json-lib`并不是一个独立的库,它需要一些其他的开源组件来支持其功能,这些依赖库在你提供的压缩包中已经包含: 1. **HTTPClient-0.3-3.jar**: 这是一个...
Java下常见的Json类库有Gson、JSON-lib和Jackson等,Jackson相对来说比较高效,在项目中主要使用Jackson进行JSON和Java对象转换
jackson lib-用于JSON 格式数据转换的类库,性能特别高,亲测可用。 jackson lib-用于JSON 格式数据转换的类库,性能特别高,亲测可用。 jackson lib-用于JSON 格式数据转换的类库,性能特别高,亲测可用。 jackson ...
Java下常见的Json类库有Gson、JSON-lib和Jackson等,Jackson相对来说比较高效,在项目中主要使用Jackson进行JSON和Java对象转换
Java下常见的Json类库有Gson、JSON-lib和Jackson等,Jackson相对来说比较高效,在项目中主要使用Jackson进行JSON和Java对象转换
Java下常见的Json类库有Gson、JSON-lib和Jackson等,Jackson相对来说比较高效,在项目中主要使用Jackson进行JSON和Java对象转换
json-lib是Java平台上的一个开源项目,它提供了一套全面的JSON操作API,支持多种流行的Java类库,如Jackson、Eclipse Collections、Apache Commons Lang等。该项目的主要目标是使Java程序员能够轻松地将JSON与Java...
`json-lib` 包含了对多种Java类库的支持,如JavaBeans、Map、Collection、JDOM、XML等,使得在处理JSON时可以灵活地与各种数据结构进行交互。在Java开发中,`json-lib` 可以作为一个便捷的工具引入到项目中,用于...
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,常用于服务器与客户端之间的数据传输。`json-lib` 是一个Java实现的JSON库,它允许将Java对象转换为JSON格式,反之亦然。`json-lib-2.4-jdk15` 版本...
例如,Jackson以其高性能和强大的功能而著称,Gson则因其与Google的生态紧密集成而流行。 在实际开发中,理解和熟练使用这些JSON库能够极大地提高开发效率,确保数据的准确交换,同时简化了后端和前端之间的接口...
如Jackson、Gson或其他JSON处理库,也可能包含了一些通用的工具类库,如Apache Commons Lang、 Commons BeanUtils等,它们提供了丰富的Java对象操作和转换功能,使得`json-lib`能更高效地工作。 在Java开发环境中,...
JSON(JavaScript Object Notation)是一种轻...然而,需要注意的是,由于`json-lib`的版本相对较老,对于新版本的Java和JSON标准的支持可能不够完善,因此在新项目中,可能需要考虑使用更新的库,如Jackson或Gson等。
三、四种JSON类库性能测试 3.1 Java对象序列化为JSON字符串 运行100万次转换,以上四种类库的性能测试如下: 表1 Java对象序列化为JSON对象 库名 耗时 Gson 47.891s Json-lib 31.7446s Jackson 20.534s FastJson...
Jackson可以轻松的将Java对象转换成...1、按性能比较,Jackson > Gson > Json-lib。Jackson的处理能力甚至高出Json-lib有10倍左右 2、JSON-lib似乎已经停止更新,最新的版本也是基于JDK15,而Jackson的社区则较为活跃;
在Java编程中,JSON-JAR包通常指的是包含处理JSON数据的相关类库,这些类库使得Java开发者能够方便地将Java对象转换为JSON格式,或者将JSON字符串反序列化为Java对象。 在Java中,最常用的JSON处理库有Jackson、...
在Java中,处理JSON通常需要借助于第三方库。标题提到的“java创建 解析json lib包”指的是用于Java开发的JSON处理库,这些库可以帮助开发者方便地创建、解析和操作JSON对象。 在描述中提到的“包含json需要的所有...
4. **与其他库的比较**:与Gson和Jackson相比,json-lib在某些性能测试中可能略逊一筹,但它的优点在于兼容性广泛,对于旧版本的Java或不支持新特性的环境更为友好。Gson和Jackson在性能和易用性方面更胜一筹,特别...