对于基础知识的学习和理解,请参看两者的官方网站:
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效率更高。
详细可执行代码参考附件内容。
相关推荐
QT 编写的例子, Json to Bson,Bson To Json, 可转化成QJsonDocument, 然后使用QT自带的Json引擎解析
Golang 中 Bson 转 Json 、Json转Bson的简单使用, 并没有太多技巧, 在博文中也有说到, 自行看博文
mongodb-json-files:网络上精选的JSON BSON数据集列表,以便在MongoDB中实践使用
JSON到BSON for Golang 帮助开发人员生成Go BSON类映射的模块执照此回购协议在涵盖。
Newtonsoft.Json.dll(.NET2.0_3.5_4.0_4.5) using Newtonsoft.Json; //DataTable转json public string DtToJson(DataTable table) { string jsonString = string.Empty; jsonString = JsonConvert....
JSON-BSON 和 BSON-JSON 转换器JBUtils.java 文件包含 7 个函数: 功能描述从文件中读取 JSON 它将输入文件的路径作为参数,读取字符串,将其转换为 JSONObject 并返回它。 从文件中读取 BSON 它将输入文件的路径...
bson jar包
bson-json-to-csv 从嵌套的bson / json文件中创建平面的csv文件 用法 适用于json / bson对象流。 例如, { " name " : " john " , " location " : { " city " : " mumbai " , " country " : " india " } } {...
Jackson JSON处理器的一个BSON生器和解析器
赠送jar包:bson-4.2.3.jar; 赠送原API文档:bson-4.2.3-javadoc.jar; 赠送源代码:bson-4.2.3-sources.jar; 赠送Maven依赖信息文件:bson-4.2.3.pom; 包含翻译后的API文档:bson-4.2.3-javadoc-API文档-中文...
bson3.6.4所用的jar包,亲测可用,java操作mongodb数据库用得到
C++实现的BOSN bson-cpp的编译
波动率/恐慌指数VIX数据(exce/bson/json) - 根据实盘原始股票期权行情数据计算VIX从2015-01至2020-07-08(持续更新中...) - 根据[White Paper Cboe Volatility Index]...
jibby-Go中的高性能流JSON到BSON解码器 吉比(jibby):描述异常积极的氛围,态度或影响力的总称。 〜城市词典 jibby软件包提供了对象到文档的高性能转换。 主要功能包括: 流解码-空格分隔或来自JSON数组容器 ...
赠送jar包:bson-4.2.3.jar; 赠送原API文档:bson-4.2.3-javadoc.jar; 赠送源代码:bson-4.2.3-sources.jar; 赠送Maven依赖信息文件:bson-4.2.3.pom; 包含翻译后的API文档:bson-4.2.3-javadoc-API文档-中文...
主要给大家介绍了关于mongodb BSON的基本使用教程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
BSON for Jackson此库将对BSON的支持添加到Jackson JSON处理器中。 BSON是JSON的二进制表示形式。 它通过用作Jackson的文档或BSON的主要交换和持久性格式而倍受关注,该库在Jackson JSON处理器中增加了对BSON的支持...
JSON查看工具, 可将json字符串格式化,,并且查看和检索json数据。
C# BSON 传输协议库 WP7可用,.net 可用