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>
如果你已經在你的classpath下有了不同版本的asm了的話,上述依賴可能會碰到問題。這時你可以使用kyro-shaded jar包,它自身包含了它所需版本的asm,并且是位于在不同包里的。
<dependency><groupId>com.esotericsoftware</groupId><artifactId>kryo-shaded</artifactId><version>4.0.1</version>
</dependency>
如果你想試用最新的特性
<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類處理緩存字節和刷新到流中。
參考連接:
- Kryo官網
- 用于網絡的Kryo
- Kryo為什么比Hessian快
原文發布于:http://www.yesdata.net/2018/03/17/kyro/