-
Java 提供了一种对象序列化的机制,该机制中,一个对象可以被表示为一个字节序列,该字节序列包括该对象的数据、有关对象的类型的信息和存储在对象中数据的类型。
-
将序列化对象写入文件之后,可以从文件中读取出来,并且对它进行反序列化,也就是说,对象的类型信息、对象的数据,还有对象中的数据类型可以用来在内存中新建对象。
-
整个过程都是 Java 虚拟机(JVM)独立的,也就是说,在一个平台上序列化的对象可以在另一个完全不同的平台上反序列化该对象。
-
一个类的对象要想序列化成功,必须满足两个条件:
该类必须实现 java.io.Serializable 接口或Externalizable接口
该类的所有属性必须是可序列化的?。如果有一个属性不是可序列化的,则该属性必须注明是短暂的。 -
使用序列化与反序列化,一是可以实现数据的持久化,把数据永久地保存到硬盘上(通常存放在文件里);二是有助于对象数据的远程通信。
当两个进程进行远程通信时,可以相互发送各种类型的数据,包括文本、图片、音频、视频等,而这些数据都会以二进制序列的形式在网络上传送。当两个Java进程进行通信时,发送方需要把这个Java对象转换为字节序列,然后在网络上传送;另一方面,接收方需要从字节序列中恢复出Java对象。
-
JDK类库中序列化API
java.io.ObjectOutputStream
:表示对象输出流
它的writeObject(Object obj)
方法可以对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中。java.io.ObjectInputStream
:表示对象输入流
它的readObject()
方法源输入流中读取字节序列,再把它们反序列化成为一个对象,并将其返回。
【参考文档】https://www.nowcoder.com/tutorial/10001/11daa075ab024a63b23365ec04a6f404