Java底层(一) - Java中的对象序列化

    最近想看看Java底层点的东西,一看就看到了Java的对象序列化。

    刚开始看觉得很头痛。不知道序列化为何方神圣,看起来玄乎其玄的,但是看了java对它的定义就觉得原来对象序列化是so easy的。下面说说我对序列化的理解:

    当我们把一个对象通过网络传递到远程端,很多人可能是用RMI远程方法调用,但是具体的RMI是如何实现的我们很模糊很费解。这就说明了“对象序列化”的作用,就是把一个对象通过网络传到远程端。

    对象的序列化就是将对象的状态存储起来,先讲对象的字段和属性以及类名转换为字节流,然后把字节流写入数据流。对象序列化的目的是将对象持久化,经过持久化的对象可以从一个地方传达到另一个地方。通过对象的反序列化得到与原对象完全相同的副本。

    只有实现了java.io.Serializable或者Externalizable接口的类的对象才能被序列化。实现Externalizable接口的类完全由自身来控制序列化的行为,而仅实现Serializable接口的类可以采用默认的序列化方式。

    对象序列化包括如下步骤:

    1.创建一个对象输出流,可以包装一个其他类型的目标输出流,如文件输出流。通过对象输出流的writeObject(obj)方法写对象:

        ObjectOutputStream为对象输出流,它的writeObject(obj)方法可对参数指定的obj对象进行序列化

   对象的反序列化:

    1.创建一个对象输入流,通过对象输入流ObjectInputStream的readObject(obj)方法读取对象。

你可能感兴趣的:(java,对象序列化)