首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用DataSerializable序列化Hazelcast 3.5

用DataSerializable序列化Hazelcast 3.5
EN

Stack Overflow用户
提问于 2015-07-21 13:37:02
回答 1查看 537关注 0票数 5

我想序列化一个Book对象:

代码语言:javascript
复制
public class Book implements DataSerializable {

    @Override
    void writeData(ObjectDataOutput out) throws IOException {
        ...
    }
    @Override
    void readData(ObjectDataInput in) throws IOException {
        ...
    }

}

问题是,我不知道如何实例化ObjectDataOutput/ObjectDataInput类型的对象来序列化/反序列化Book对象。

ObjectDataOutputStream实现ObjectDataOutput,但我不知道如何实例化这个对象,因为它需要没有公共构造函数的SerializationService对象。

那么,是否有任何方法可以从FileOutputStream/FileInputStream创建ObjectDataOutput/ObjectDataInput对象?

提前感谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-07-22 11:54:09

多亏了@pveentjer,我找到了答案。

代码语言:javascript
复制
FileOutputStream fos = new FileOutputStream(file);
ByteArrayOutputStream bos = new ByteArrayOutputStream();
SerializationService serializationService = new DefaultSerializationServiceBuilder().build();
ObjectDataOutput odo = new ObjectDataOutputStream(bos, serializationService);

Book book = new Book();
book.writeData(odo);
bos.writeTo(fos);
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31540665

复制
相关文章

相似问题

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