日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

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

發布時間:2023/12/19 windows 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 分布式系统开发工具包 —— 基于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>

如果你已經在你的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/

總結

以上是生活随笔為你收集整理的分布式系统开发工具包 —— 基于Kryo的Java对象序列化的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。