zoukankan      html  css  js  c++  java
  • (转)FastJson---高性能JSON开发包

    场景:javaBean对象转化为json对象!

    1 Fastjson介绍

    Fastjson是一个Java语言编写的JSON处理器,由阿里巴巴公司开发。
    1、遵循http://json.org标准,为其官方网站收录的参考实现之一。
    2、功能qiang打,支持JDK的各种类型,包括基本的JavaBean、Collection、Map、Date、Enum、泛型。
    3、无依赖,不需要例外额外的jar,能够直接跑在JDK上。
    4、开源,使用Apache License 2.0协议开源。http://code.alibabatech.com/wiki/display/FastJSON/Home
    5、具有超高的性能,java世界里没有其他的json库能够和fastjson可相比了。

    如果获得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/FASTJSON

    如果你使用了Maven,maven repository配置如下:

    <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,可以直接下载:

    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.JSON

    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:

    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代码示例:

    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优越的性能表现,我建议做如下事情;
    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/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/

    1

  • 相关阅读:
    mysql索引
    mysql视图
    pymysql
    web前端基础
    【BZOJ2002】[HNOI2010] 弹飞绵羊(大力分块)
    【BZOJ2730】[HNOI2012] 矿场搭建(找割点)
    网络流(一)——最大流
    欧拉路与欧拉回路
    扫描线(一)——求矩形面积并
    【洛谷3396】哈希冲突(大力分块)
  • 原文地址:https://www.cnblogs.com/lixuwu/p/6538617.html
Copyright © 2011-2022 走看看