首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Kryo类加载器问题

Kryo类加载器问题
EN

Stack Overflow用户
提问于 2018-02-14 07:19:54
回答 1查看 648关注 0票数 0

我有两个应用程序: Application1使用Kryo序列化程序序列化have对象,application2反序列化由application1保存在外部存储上的kryo序列化byte[]。

Application1的类路径中有kryo-shaded-3.0.3.jar,而application2的类路径中有kryo-shaded-4.0.1。

当application2试图反序列化byte[]时,它得到了一个异常: kryo无法使用kryo的类加载器加载类,正在使用current重试。

当我在application1中更改kryo的版本时,也是kryo-shaded-4.0.1。它工作得很好。当序列化程序有不同的版本时为什么会有问题。谁设置了kryo类加载器?

EN

回答 1

Stack Overflow用户

发布于 2018-02-14 12:05:13

当序列化程序有不同的版本时,为什么会有问题?

当Kryo将数据序列化为字节数组时,它会将对象的内容打包成特定的格式。Kryo将数据打包成字节数组的确切方式因Kryo的不同版本而异。因此,如果使用版本3.0.3序列化数据,则格式将与版本4.0.1预期的格式不同。因此,如果您以接收者不理解的格式向接收者发送字节,就不能期望接收者正确地处理数据。

谁设置了kryo类加载器?

我不确定Kryo的内部结构,但我认为它可能使用与默认情况下运行代码的线程相同的类加载器。如果你愿意,你可以设置一个替代的类加载器,但是你必须检查文档。

您观察到的kryo unable to load class with Kryo's classloader retrying with current异常很可能是因为接收器误读了发送给他的字节数组。例如,如果发送方发送了一个内容为com.my.class.TestXXXXXXX的字节数组,其中类名在开头,但接收方希望类名在末尾,并将类名读取为XXXXXXX。然后Kryo将使用类加载器来查找类XXXXXXX,但他将失败,因为没有类XXXXXXX。为什么接收器上的Kryo首先需要查找类?因为他需要实例化您发送的对象,为此,他需要调用对象的Class的no-arg构造函数。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48777270

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档