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

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

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 Object fromJson(String jsonAsString, Class 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效率更高。

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

java json to bson_JSON BSON 效率比较相关推荐

  1. 从JSON进化到BSON

    自从MEAN引导的JSON数据格式取代传统JAVA推崇的XML以后, json的发展却停滞不前了, 当然这是好事, 因为稳定的结构是不需要向下兼容的, 但是json之所以轻便简单就是源于它的类型, 额 ...

  2. Java JSON library哪家强?

    Java JSON Library benchmark 测试 今天同事之间的一个讨论,引起了我的好奇,Java JSON libary哪家强? 搜索了一番,看到一篇文章 http://blog.tak ...

  3. java json lib 日期

    2019独角兽企业重金招聘Python工程师标准>>> java json lib 日期 博客分类: java JSONObject jsonPerson = JSONObject. ...

  4. 用Jackson进行Java JSON处理

    JSON (Javascript对象符号)正成为一种非常流行的数据交换格式. 在使用诸如YUI,ExtJS,DOJO等Javascript框架开发Web应用程序时,我们可以使用XML或JSON在客户端 ...

  5. java json 易用_Java中 Json的使用

    Java JSON 本章节我们将为大家介绍如何在 Java 语言中使用 JSON. 类库选择 Java中并没有内置JSON的解析,因此使用JSON需要借助第三方类库. 下面是几个常用的 JSON 解析 ...

  6. java json和对象互相装换

    java json和对象互相装换 1.com.alibaba.fastjson.JSON 2.com.fasterxml.jackson.databind.ObjectMapper 转载于:https ...

  7. Java JSON库Jackson 2 x新变化一览

    <Java JSON库Jackson 2.x新变化一览> 作者:chszs,转载需注明. 作者博客主页:http://blog.csdn.net/chszs Jackson库是JSON J ...

  8. Java Json格式化工具

    Java Json格式化工具 Java 实现Json格式化工具 代码地址: https://github.com/AndroidJavaToolsDemo/JavaTool_JsonValidate ...

  9. Java JSON格式简介说明

    转自: Java JSON格式简介说明 下文笔者讲述java中JSON格式的相关简介说明,如下所示: JSON简介说明 JSON(JavaScript Object Notation) 是一种轻量级的 ...

最新文章

  1. 单线程下的生产者--消费者模式详解,wait和sleep的区别
  2. MySQL存储引擎之Myisam和Innodb总结性梳理
  3. 在 node.js 的 express web 框架中自动注册路由
  4. Linux进阶之路————CentOS网络配置
  5. Fragment与Activity传递数据
  6. bubble html5,利用HTML5 Canvas创建交互式Bubble Chart
  7. 【LeetCode】7. Reverse Integer
  8. 控制工程基础Chapter2 Mathematical models of systems
  9. VB 按指定编码格式写入文本文件
  10. .NET清除Session 的几个方法[clear/removeAll/remove/Abandon]
  11. 2021-10-22 学习笔记:和弦对照信息表
  12. python安装caffe_caffe中安装python
  13. AI智能语音识别算法原理 四
  14. win10 如何设置绿色保护色?
  15. 北斗垂莽苍 开闭天门路(上)
  16. 3:AngularJS:模糊查询过滤内容,下拉菜单排序,过滤敏感字符,验证判断后添加表格信息
  17. 关于npm i 的那点事
  18. docx文件转pdf,使用aspose words 转pdf,并且解决表格格式错乱
  19. oracle怎么绑定vue,Oracle AutoVue 安装与配置教程,oracleautovue
  20. 杰理之GSENSOR【篇】

热门文章

  1. 对学校的希望和寄语_家长对孩子的希望和寄语
  2. 微软ERP Axapta与Sap、Oracle的比较
  3. DP线和HDMI的区别?
  4. 五龙亭构造_电话亭到蟑螂:无线热点的演变
  5. Amq 使用+springboot
  6. vs打开别人cpp_网恋奔现遇到现实版乔碧萝,怀疑她拿了别人的照片……
  7. <insert></insert>
  8. MYSQL之not in优化方法:left join
  9. 数列的定义如下: 数列的第一项为n,以后将此为前一项的平方根,求数列的前m项的和。
  10. 光纤传感器实验模块_光纤位移传感器实验教学改进