代码示例:
代码示例用到类User和Group:
public class User {
private Long id;
String name;
public Long getId() { return id; }
public void setId(Long id) { this.id = id; }
String getName() { return name; }
public void setName(String name) { this.name = name; }
}
public class Group {
String name;
private List<User> users = new ArrayList<User>();
this.name = name; }
public List<User> getUsers() { return users; }
public void setUsers(List<User> users) { this.users = users; }
}
Encode代码示例:
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);
之前的一个版本是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优越的性能表现,我建议做如下事情;
1、替换其他所有的json库,java世界里没有其他的json库能够和fastjson可相比了。
2、使用fastjson的序列化和反序列化替换java serialize,java serialize不单性能慢,而且体制大。
3、使用fastjson替换hessian,json协议不必hessian体积大,而且fastjson性能优越,数倍于hessian
4、把fastjson用于memached缓存对象数据。
How to get it?
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>
Downlaods
Binary :http://code.alibabatech.com/svn/fastjson/