分布式系统开发工具包 —— 基于Kryo的Java对象序列化

Kryo是用于Java语言的一个快速和高效的对象图序列化框架。Kryo项目的目的是快速、高效、方便地使用API。当须要持久化对象的时候,不管是持久化到文件、数据库仍是网络,均可以使用Kryo。数据库

目前Kryo已经到了4.0.1版本以上了。本文的介绍适用于V2.0+以上版本。缓存

安装Kryo

通常适用maven来Kryo包。网络

使用官方版的Kryo的话能够引用下述配置代码框架

<dependency>
    <groupId>com.esotericsoftware</groupId>
        <artifactId>kryo</artifactId>
    <version>4.0.1</version>
</dependency>

<!--more-->maven

若是你已经在你的classpath下有了不一样版本的asm了的话,上述依赖可能会碰到问题。这时你能够使用kyro-shaded jar包,它自身包含了它所需版本的asm,而且是位于在不一样包里的。url

<dependency>
    <groupId>com.esotericsoftware</groupId>
        <artifactId>kryo-shaded</artifactId>
    <version>4.0.1</version>
</dependency>

若是你想试用最新的特性spa

<repository>
   <id>sonatype-snapshots</id>
   <name>sonatype snapshots repo</name>
   <url>https://oss.sonatype.org/content/repositories/snapshots</url>
</repository>
    
<dependency>
   <groupId>com.esotericsoftware</groupId>
       <artifactId>kryo</artifactId>
   <version>4.0.1-SNAPSHOT</version>
</dependency>

开始使用Kryo库

import com.esotericsoftware.kryo.Kryo;
import com.esotericsoftware.kryo.io.Output;
import com.esotericsoftware.kryo.io.Input;
// ...
Kryo kryo = new Kryo();
// ...
Output output = new Output(new FileOutputStream("file.bin"));
SomeClass someObject = ...
kryo.writeObject(output, someObject);
output.close();
// ...
Input input = new Input(new FileInputStream("file.bin"));
SomeClass someObject = kryo.readObject(input, SomeClass.class);
input.close();

Kryo类编排序列化,Output和Input类处理缓存字节和刷新到流中。.net

本文为摘录,原文发布于:http://www.yesdata.net/2018/03/17/kyro/code

相关文章
相关标签/搜索