脚本宝典收集整理的这篇文章主要介绍了分布式系统开发工具包 —— 基于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-->
如果你已经在你的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的Java对象序列化全部内容,希望文章能够帮你解决分布式系统开发工具包 —— 基于Kryo的Java对象序列化所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。