详解Jackson 使用以及性能介绍
直接上代码,看下最简单也是最常用的方法,将object 转为 json 以及将json转为object方式
public class testjackson { public static void main(string[] args) throws ioexception { objectmapper objectmapper = new objectmapper(); map<string,object> params = new hashmap<>(); params.put("name","jack"); params.put("age",18); //将对象转为json串 string jsonstring = objectmapper.writevalueasstring(params); system.out.println(jsonstring); system.out.println("--------------------分割线-----------------------------"); //将json串 转为 object 对象 map resultmap = objectmapper.readvalue(jsonstring, hashmap.class); resultmap.entryset().stream().foreach(entry ->{ system.out.println(entry); }); } }
如果你只是忘了怎么操作,或者只是想知道怎么对象和json串如何相互转,那么你看到这就足够了,如果你想了解更多关于jackson,以及jackson与fastjson等的对比,那么可以往下看。
介绍
jackson 是当前用的比较广泛的,用来序列化和反序列化 json 的 java 的开源框架。jackson 社 区相对比较活跃,更新速度也比较快, 从 github 中的统计来看,jackson 是最流行的 json 解析器之一 。 spring mvc 的默认 json 解析器便是 jackson。 jackson 优点很多。 jackson 所依赖的 jar 包较少 ,简单易用。与其他 java 的 json 的框架 gson 等相比, jackson 解析大的 json 文件速度比较快;jackson 运行时占用内存比较低,性能比较好;jackson 有灵活的 api,可以很容易进行扩展和定制。
jackson 的 1.x 版本的包名是 org.codehaus.jackson ,当升级到 2.x 版本时,包名变为 com.fasterxml.jackson,本文讨论的内容是基于最新的 jackson 的 2.9.1 版本。
组件
- jackson-core,核心包,提供基于"流模式"解析的相关 api,它包括 jsonpaser 和 jsongenerator。 jackson 内部实现正是通过高性能的流模式 api 的 jsongenerator 和 jsonparser 来生成和解析 json。
- jackson-annotations,注解包,提供标准注解功能;
- jackson-databind ,数据绑定包, 提供基于"对象绑定" 解析的相关 api ( objectmapper ) 和"树模型" 解析的相关 api (jsonnode);基于"对象绑定" 解析的 api 和"树模型"解析的 api 依赖基于"流模式"解析的 api。
pom依赖
<dependency> <groupid>com.fasterxml.jackson.core</groupid> <artifactid>jackson-databind</artifactid> <version>2.9.5</version> </dependency>
jackson-databind 依赖 jackson-core 和 jackson-annotations,当添加 jackson-databind 之后, jackson-core 和 jackson-annotations 也随之添加到 java 项目工程中。在添加相关依赖包之后,就可以使用 jackson。
信息配置
在调用 writevalue 或调用 readvalue 方法之前,往往需要设置 objectmapper 的相关配置信息。这些配置信息应用 java 对象的所有属性上
//在反序列化时忽略在 json 中存在但 java 对象不存在的属性 objectmapper.configure(deserializationfeature.fail_on_unknown_properties, false); //在序列化时日期格式默认为 yyyy-mm-dd't'hh:mm:ss.sssz objectmapper.configure(serializationfeature.write_dates_as_timestamps,false); //在序列化时忽略值为 null 的属性 objectmapper.setserializationinclusion(jsoninclude.include.non_null); //忽略值为默认值的属性 objectmapper.setdefaultpropertyinclusion(jsoninclude.include.non_default);
更多配置信息可以查看 jackson 的 deserializationfeature,serializationfeature 和 i nclude。
注解使用
jack还提供了注解方式的使用
注解 | 用法 |
---|---|
@jsonproperty | 用于属性,把属性的名称序列化时转换为另外一个名称。示例: @jsonproperty("birth_ d ate") private date birthdate; |
@jsonformat | 用于属性或者方法,把属性的格式序列化时转换成指定的格式。示例: @jsonformat(timezone = "gmt+8", pattern = "yyyy-mm-dd hh:mm") public date getbirthdate() |
@jsonpropertyorder | 用于类, 指定属性在序列化时 json 中的顺序 , 示例: @jsonpropertyorder({ "birth_date", "name" }) public class person |
@jsoncreator | 用于构造方法,和 @jsonproperty 配合使用,适用有参数的构造方法。 示例: @jsoncreator public person(@jsonproperty("name")string name) {…} |
@jsonanysetter | 用于属性或者方法,设置未反序列化的属性名和值作为键值存储到 map 中 @jsonanysetter public void set(string key, object value) { map.put(key, value); } |
@jsonanygetter | 用于方法 ,获取所有未序列化的属性 public map<string, object> any() { return map; } |
public class testjackson { public static void main(string[] args) throws ioexception { objectmapper objectmapper = new objectmapper(); //将对象转为json串 string jsonstring = objectmapper.writevalueasstring(new user()); system.out.println(jsonstring); } } class user { @jsonproperty("name") private string aaa = "hello"; @jsonproperty("date") @jsonformat(pattern = "yyyy-mm-dd hh:mm:ss") private date bbb = new date(); ...省略setter 和 getter... }
读取对象转换 还可以从 reader ,file,url,以及inputstream,字节数组中等 中获取对象数据,喜欢的可以自己研究下
那么性能如何呢?
对比对象选择应用最广泛的jackson和google出品的gson。测试环境选择jdk 8,amd 3700x,3200mhz内存。简化实验,只测试简单对象和复杂对象的string转对象、对象转string,调用1千万次的对比结果如下(时间单位是毫秒):
从测试结果看,fastjson确实是最快的,但仅比jackson快20%左右,google的gson是最慢的,差距较大。读到这里,是不是觉得选择fastjson肯定没错啊!但其实,fastjson在国际上并不是很流行,反而jackson很流行,难道其他人傻?当然不是,因为fastjson这两年频频被曝出高危漏洞,这也是早已埋下的伏笔,因为fastjson为了追求快,舍弃了很多方面,比如失去了元贝应该兼容的java特性,对json标准遵循也不严格,总体来说,fastjson是一个代码质量较差的国产类库,当然它也在不断的提升改变,也希望它继续坚持。
如果面试官问为什么选择fastjson?因为快!这一个理由就可以把他顶回去了。
这里的调查研究并不是很充分,没有对内存占用、大文档的测试。
在现代应用程序中,即使最慢的gson,也是满足需求的;解析文档速度的快慢,并不能作为选型的唯一标准,可能连主要标准都算不上。对io优化,并行处理等优化措施,比选用一个更快的库更有效。
所以整体上来说jackson 综合评价应该是很不错的。
到此这篇关于详解jackson 使用以及性能介绍的文章就介绍到这了,更多相关jackson 使用及性能内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!