• Java IO: 序列化与ObjectInputStream、ObjectOutputStream


    作者:Jakob Jenkov  译者: 李璟(jlee381344197@gmail.com)

    本小节会简要概括Java IO中的序列化以及涉及到的流,主要包括ObjectInputStream和ObjectOutputStream。

    Serializable

    原文链接

    如果你希望类能够序列化和反序列化,必须实现Serializable接口,就像所展示的ObjectInputStream和ObjectOutputStream例子一样。

    对象序列化本身就是一个主题。Java IO系列教程主要关注流、reader和writer,所以我不会深入探讨对象序列化的细节。并且,目前在网上已经有很多文章探讨了对象序列化,我将给出几个深入分析的资料链接,不再赘述。链接如下:

    http://java.sun.com/developer/technicalArticles/Programming/serialization/

    ObjectInputStream

    原文链接

    ObjectInputStream能够让你从输入流中读取Java对象,而不需要每次读取一个字节。你可以把InputStream包装到ObjectInputStream中,然后就可以从中读取对象了。代码如下:

    1 ObjectInputStream input = new ObjectInputStream(new FileInputStream("object.data"));
    2  
    3 MyClass object = (MyClass) input.readObject(); //etc.
    4  
    5 input.close();

    在这个例子中,你读取的对象必须是MyClass的一个实例,并且必须事先通过ObjectOutputStream序列化到“object.data”文件中。(译者注:ObjectInputStream和ObjectOutputStream还有许多read和write方法,比如readInt、writeLong等等,详细信息请查看官方文档)

    在你序列化和反序列化一个对象之前,该对象的类必须实现了java.io.Serializable接口。

    ObjectOutputStream

    原文链接

    ObjectOutputStream能够让你把对象写入到输出流中,而不需要每次写入一个字节。你可以把OutputStream包装到ObjectOutputStream中,然后就可以把对象写入到该输出流中了。代码如下:

    1 ObjectOutputStream output = new ObjectOutputStream(new FileOutputStream("object.data"));
    2  
    3 MyClass object = new MyClass();  output.writeObject(object); //etc.
    4  
    5 output.close();

    例子中序列化的对象object现在可以从ObjectInputStream中读取了。

    同样,在你序列化和反序列化一个对象之前,该对象的类必须实现了java.io.Serializable接口。

    原创文章,转载请注明: 转载自并发编程网 – ifeve.com本文链接地址: Java IO: 序列化与ObjectInputStream、ObjectOutputStream

  • 相关阅读:
    Navicat for Mysql安装及破解教程
    如何down掉IB交换机口
    pycharm替换文件中所有相同字段方法
    NAS、SAN、ISCSI存储
    Linux系统下安装rz/sz命令及使用说明
    python 实现查找某个字符在字符串中出现次数,并以字典形式输出
    python class用法
    zookeeper
    机器学习基础
    hive--数据仓库
  • 原文地址:https://www.cnblogs.com/dassmeta/p/5323936.html
Copyright © 2020-2023  润新知