当前位置:首页 > 开发 > 编程语言 > Json > 正文

JSON BSON 效率比较

发表于: 2015-04-30   作者:Deo   来源:转载   浏览次数:
摘要: 对于基础知识的学习和理解,请参看两者的官方网站: JSON: http://www.json.org/ BSON: http://bsonspec.org/   这里主要介绍两者对于POJO的转换方式以及效率比对。 选择 Jackson JSON Processor 和 bson4jackson 来作为转换器,是因为这

对于基础知识的学习和理解,请参看两者的官方网站:

JSON: http://www.json.org/

BSON: http://bsonspec.org/

 

这里主要介绍两者对于POJO的转换方式以及效率比对。

选择 Jackson JSON Processor 和 bson4jackson 来作为转换器,是因为这两款产品在开发中用的最多。

 

1. JSON

Jackson提供三种方法处理JSON:

  • Streaming API :reads and writes JSON content as discrete events. 该方式效率最高(相比于其他两种方式)

  • Tree Model:provides a mutable in-memory tree representation of a JSON document,该方式最灵活

  • Data Binding:couverts JSON to and from POJOs based either on property accessor conventions or annotations. 这种方式通常是最方便的。

先提供一个实体类 -- User entity (User.java 代码参看附件),JSON表示如下:

{
  "name" : { "first" : "Joe", "last" : "Sixpack" },
  "gender" : "MALE",
  "verified" : false,
  "userImage" : "Rm9vYmFyIQ=="
}

 JSON 和 POJO的转换程序如下:

 

public class JsonPojoMapper {
	private static ObjectMapper m = new ObjectMapper();
	private static JsonFactory jf = new JsonFactory();

	public static <T> Object fromJson(String jsonAsString, Class<T> pojoClass) throws Exception {
		return m.readValue(jsonAsString, pojoClass);
	}

	public static String toJson(Object pojo, boolean prettyPrint)
			throws IOException {
		StringWriter sw = new StringWriter();
		JsonGenerator jg = jf.createGenerator(sw);
		if (prettyPrint) {
			jg.useDefaultPrettyPrinter();
		}
		m.writeValue(jg, pojo);
		return sw.toString();
	}
}

 

 

2. BSON

BSON short for Binary JSON, is a binary-encoded serialization of JSON-like documents.

BSON目前主要用于MongoDB中,是MongoDB的数据存储格式。

BSON文档到字符文档的转换类似于JSON,具体可参考下面的测试代码

 

3. performance测试

更高的效率是BSON的主要目标之一,但究竟和JSON比效率如何?

测试场景:100W条数据的转换,从POJO转换为JSON/BSON, 然后再转换为POJO

测试代码:

 

public class PerformanceBsonJson {
	private User src = new User();
	private User dst = new User();

	@Before
	public void setUP() {
		src.setUserName("ca bj test");
		src.setPassword("ca admin");
	}

	@Test
	public void testJson() throws Exception {
		long begin = System.currentTimeMillis();
		for (int i = 0; i < 1000000; i++) {
			String jsonString = JsonPojoMapper.toJson(src, true);
			dst = (User) JsonPojoMapper.fromJson(jsonString, User.class);
		}
		long end = System.currentTimeMillis();
		System.out.println("Transfer Json cost is: " + (end - begin) + "ms");
	}
	
	@Test
	public void testBson() throws JsonProcessingException, JsonMappingException, IOException {
		BsonFactory fac = new BsonFactory();
		fac.enable(BsonGenerator.Feature.ENABLE_STREAMING);
		ObjectMapper mapper = new ObjectMapper(fac);
		ByteArrayOutputStream baos = new ByteArrayOutputStream();
		long begin = System.currentTimeMillis();
		for(int i=0; i<1000000; i++){
			mapper.writeValue(baos, src);
			ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray());
			dst = mapper.readValue(bais, User.class);
			baos.reset();
		}
		long end = System.currentTimeMillis();
		System.out.println("Transfer Bson cost is: " + (end-begin) +"ms");
	}
}

 

 

测试结果:

        Transfer Bson cost is: 4939ms

        Transfer Json cost is: 2339ms

PS:测试结果根据选用第三方转换类库,以及转换方式不同会有不同结果。

但这种场景至少说明,在某些情况下JSON比BSON效率更高。

 

详细可执行代码参考附件内容。

JSON BSON 效率比较

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
对比代码: #include <iostream> #include <vector> #include <array> #include
以下是时间对比,第二张图是使用得递归算法,第一张图使用的栈,使用栈来实现还是要快那么一点。使
作为一种轻量级的数据交换格式,json正在逐步取代xml,成为网络数据的通用格式。 有的json代码格式
一、引子 Chrome工具里面有很多json格式化的插件,可以让杂乱的json内容变得有序,我们先来看看效果
分页很重要,面试会遇到。不妨再回顾总结一下。 1.创建测试环境,(插入100万条数据大概耗时5分钟)。
关于sql全文检索与lucene效率比较的摘要,以下仅为网络找到的效率意见,近期会对效率做出测试比较,
很多年以后,还有很多程序员不知道SQL Server2005有了更方便的分页方法,这就是ROW_NUMBER()函数。
1. BSON源码结构 涉及BSON的源码有: builder.h 包含bson所需的内存管理类和将bson对象转成内存的工
BSON是由10gen开发的一个数据格式,目前主要用于MongoDB中,是MongoDB的数据存储格式。BSON基于JSON
Java中哪个JSON库的解析速度是最快的? JSON已经成为当前服务器与WEB应用之间数据传输的公认标准,
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号