Fastjson介绍java
Fastjson是一个Java语言编写的JSON处理器,由阿里巴巴公司开发。
一、遵循http://json.org标准,为其官方网站收录的参考实现之一。
二、功能qiang打,支持JDK的各类类型,包括基本的JavaBean、Collection、Map、Date、Enum、泛型。
三、无依赖,不须要例外额外的jar,可以直接跑在JDK上。
四、开源,使用Apache License 2.0协议开源。http://code.alibabatech.com/wiki/display/FastJSON/Home
五、具备超高的性能,java世界里没有其余的json库可以和fastjson可相比了。git
若是得到Fastjson?
SVN:http://code.alibabatech.com/svn/fastjson/trunk/
WIKI:http://code.alibabatech.com/wiki/display/FastJSON/Home
Issue Tracking:http://code.alibabatech.com/jira/browse/FASTJSONgithub
若是你使用了Maven,maven repository配置以下:web
<repository> <id>opensesame</id> <name>Alibaba OpenSource Repsoitory</name> <url>http://code.alibabatech.com/mvn/releases/</url> <snapshots> <enabled>false</enabled> </snapshots> </repository>
pom.xml文件中加入依赖依赖:算法
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.0.4</version> </dependency>
若是没有使用maven,能够直接下载:json
Binary : http://code.alibabatech.com/mvn/releases/com/alibaba/fastjson/1.1.1/fastjson-1.1.1.jar
Source :http://code.alibabatech.com/mvn/releases/com/alibaba/fastjson/1.1.1/fastjson-1.1.1-sources.jar
Subversion : http://code.alibabatech.com/svn/fastjson/缓存
使用介绍:
Fastjson的最主要的使用入口是com.alibaba.fastjson.JSONjvm
import com.alibaba.fastjson.JSON; public static final Object parse(String text); // 把JSON文本parse为JSONObject或者JSONArray public static final JSONObject parseObject(String text); // 把JSON文本parse成JSONObject public static final <T> T parseObject(String text, Class<T> clazz); // 把JSON文本parse为JavaBean public static final JSONArray parseArray(String text); // 把JSON文本parse成JSONArray public static final <T> List<T> parseArray(String text, Class<T> clazz); //把JSON文本parse成JavaBean集合 public static final String toJSONString(Object object); // 将JavaBean序列化为JSON文本 public static final String toJSONString(Object object, boolean prettyFormat); // 将JavaBean序列化为带格式的JSON文本 public static final Object toJSON(Object javaObject); 将JavaBean转换为JSONObject或者JSONArray。
代码示例:
代码示例用到类User和Group:maven
public class User { private Long id; private String name; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } } public class Group { private Long id; private String name; private List<User> users = new ArrayList<User>(); public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public List<User> getUsers() { return users; } public void setUsers(List<User> users) { this.users = users; } }
Encode代码示例:svn
import com.alibaba.fastjson.JSON; Group group = new Group(); group.setId(0L); group.setName("admin"); User guestUser = new User(); guestUser.setId(2L); guestUser.setName("guest"); User rootUser = new User(); rootUser.setId(3L); rootUser.setName("root"); group.getUsers().add(guestUser); group.getUsers().add(rootUser); String jsonString = JSON.toJSONString(group); System.out.println(jsonString);
Decode 代码示例:
Group group2 = JSON.parseObject(jsonString, Group.class);
以前的一个版本是1.1.0,1.1.0采用asm和SortFastMatch算法提升性能,因为过于着急展现其优越的性能,没有进行严格测试就发布了。
1.1.1相对于1.1.0,这是一个比较稳定的版本了,行测试覆盖率从新提高到90%以上,build verify testcase 983个。
这个版本进一步完善了asm和SortFieldFastMatch算法,进一步提高了性能,同时补充了大量的testcase,提高了稳定性,我向你推荐使用这个版本,使用这个版本你将会获得使人惊奇的性能。
1.1.1版本的asm来源自objectweb的asm项目,根据fastjson的须要作裁剪,确保引入asm的同时不引发包大小的过渡变大。
为了更好使用sort field martch优化算法提高parser的性能,fastjson序列化的时候,缺省把SerializerFeature.SortField特性打开了。反序列化的时候也缺省把SortFeidFastMatch的选项打开了。这样,若是你用fastjson序列化的文本,输出的结果是按照fieldName排序输出的,parser时也能利用这个顺序进行优化读取。这种状况下,parser可以得到很是好的性能。
我使用github.com/eishay/jvm-serializers/提供的程序作测试,性能数据以下:
序列化时间 | 反序列化时间 | 大小 | 压缩后大小 | |
---|---|---|---|---|
java序列化 | 8546 | 43199 | 889 | 541 |
hessian | 6643 | 10043 | 501 | 313 |
protobuf | 3008 | 1694 | 239 | 149 |
thrift | 3182 | 1951 | 349 | 197 |
avro | 3575 | 2095 | 221 | 133 |
json-lib | 45734 | 149741 | 485 | 263 |
jackson | 3245 | 2986 | 503 | 271 |
fastjson | 2292 | 1499 | 468 | 251 |
测试跑的脚本是:
./run -chart -include=`cat serializers.txt | tr "\\n" ","` data/media.1.cks
从上面的数据来看,fastjson的性能已经超越protobuf、thrift、avro这些二进制协议了。一个文本协议的性能超越二进制协议是很难的,我很高兴向你们宣布我作到了!!
鉴于fastjson优越的性能表现,我建议作以下事情;
一、替换其余全部的json库,java世界里没有其余的json库可以和fastjson可相比了。
二、使用fastjson的序列化和反序列化替换Java serialize,java serialize不单性能慢,并且体制大。
三、使用fastjson替换hessian,json协议没必要hessian体积大,并且fastjson性能优越,数倍于hessian
四、把fastjson用于memached缓存对象数据。
If you're Maven user, just use our maven repository(http://code.alibabatech.com/mvn/releases/) with folloging dependency
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.1.1</version> </dependency>
Binary : http://code.alibabatech.com/mvn/releases/com/alibaba/fastjson/1.1.1/fastjson-1.1.1.jar
Source :http://code.alibabatech.com/mvn/releases/com/alibaba/fastjson/1.1.1/fastjson-1.1.1-sources.jar
Subversion : http://code.alibabatech.com/svn/fastjson/