zoukankan      html  css  js  c++  java
  • 高性能Java序列化框架Fse发布

    高性能Java序列化框架Fse发布

    使用场景

    将Java对象序列化为二进制数据进行保存,以及二进制数据反向序列化为Java对象,在很多场景中都有应用。比如将对象序列化后离线存储至其他介质,或者存储于Redis这样的缓存之中。

    目前常见的有几种框架可以支撑,比如 Hession ,Kryo,Protobuf,JDK原生等。有一些框架需要提前编写元数据配置文件以支撑跨语言序列化能力,比如 Protobuf 。不过如果团队的技术栈是统一的 Java 体系的话,则能够开箱即用的序列化框架使用起来会更加方便一些,特别有些时候对象特别复杂,编写元数据配置文件也是很繁琐的一个事情。

    Fse 框架正是应用于这样的场景,不需要编写元数据配置信息,开箱即用的 Java 序列化框架,对需要序列化的对象没有任何特殊要求。在性能基准测试中,该框架的性能表现显著优于其他框架,下面是测试对比

    欢迎加入技术交流群186233599讨论交流,也欢迎关注笔者公众号:风火说。

    使用说明

    首先在Pom文件中引入依赖,如下

    <dependency>
        <groupId>com.jfireframework</groupId>
        <artifactId>fse</artifactId>
        <version>aegean-1.0</version>
    </dependency>
    

    API 使用方式如下

    Fse fse = new Fse();
    TestData data = new TestData();
    //创建一个二进制数组容器,用于容纳序列化后的输出。容器大小会在需要时自动扩大,入参仅决定初始化大小。
    ByteArray buf = ByteArray.allocate(100);
    //执行序列化,会将序列化对象序列化到二进制数组容器之中。
    fse.serialize(data, buf);
    //得到序列化后的二进制数组结果
    byte[] resultBytes = buf.toArray();
    //清空容器内容,可以反复使用该容器
    buf.clear();
    //填入数据,准备进行反序列化
    buf.put(resultBytes);
    TestData result = (TestData) fse.deSerialize(buf);
    assertTrue(result.equals(data));
    

    开源地址

    Gitee:https://gitee.com/eric_ds/fse

    Github:https://github.com/linbin-eric/Fse

  • 相关阅读:
    delegate
    Event
    SQL:删除重复数据,只保留一条
    c#符号
    linux下vim命令详解【转】
    Probabilistic latent semantic analysis【转】
    Ubuntu下如何使用虚拟机安装WindowsXP?(2)【转】
    C文件操作fopen打开标记设置问题【学习笔记】
    Plate notation【转】
    最大似然估计(Maximum likelihood estimation) 【转】
  • 原文地址:https://www.cnblogs.com/jfire/p/12255733.html
Copyright © 2011-2022 走看看